Кривые и поверхности в компьютерной геометрии, II
Поверхности, построенные по каркасу из кривых
В проектировании поверхностей иногда применяется метод построения поверхности по дискретной совокупности ее сечений. Для затягивания остова, образованного сечениями, гладкой поверхностью применяются методы, аналогичные построению интерполяционных кривых. Поэтому получаемые таким способом поверхности имеют такие же названия, как и соответствующие интерполяционные сплайны.
Поверхности Эрмита. Напомним, что сплайном Эрмита называется кусочно-кубическая кривая, проходящая через заданные точки и имеющая в этих точках заданные производные Если производные не заданы, то в точках их можно определить из некоторых "естественных" соображений. Одним из примеров такого рода является псевдоупругий сплайн Эрмита. Еще один способ - положить по определению
(есть и другие способы).
Задание производных на концах и иногда заменяют на условие обращения в ноль третьей производной на концах кривой. Это условие равносильно следующим формулам:
Напомним, что вторые производные в опорных точках сплайна Эрмита (где происходит стык кубических кривых) претерпевают разрыв, т. е. сплайны Эрмита принадлежат классу Аналогично сплайнам Эрмита строятся поверхности Эрмита.
Пусть имеется семейство кривых
( 6.20) |
Без ограничения общности будем считать, что параметр u для всех кривых пробегает один и тот же отрезок: Тогда поверхность Эрмита, затягивающая остов кривых определяется формулой, аналогичной формуле для сплайна Эрмита:
если Здесь - местный параметр на данном участке поверхности ( ), и - производные в трансверсальном направлении на заданном остове кривых (6.20), Параметрическая область поверхности Эрмита имеет вид
Если трансверсальные производные на линиях остова не заданы, то их, аналогично случаю сплайна Эрмита, можно определить, например, так:
При таком определении третьи производные на кривых и в трансверсальном направлении обратятся в ноль:
Сами исходные кривые образующие остов поверхности Эрмита, могут быть построены как кривые Безье или B -кривые. При этом получаются поверхности класса имеющие на двух участках границы управляемые производные по трансверсальному направлению (а именно, на участках и ). На участках границы и производные, вообще говоря, управляются лишь приблизительно - с помощью выбора кривых остова
Применение поверхностей Эрмита: поверхность перехода. Примером применения поверхностей Эрмита может служить задача объединения двух поверхностей в одну общую поверхность путем соединения их краев с помощью поверхности перехода.
Пусть даны две поверхности M и N, которые надо сопрячь, соединив поверхностью перехода край первой поверхности и край второй поверхности. Будем считать, что оба сопрягаемых края отнесены к одному и тому же параметру t, изменяющемуся в пределах Второй параметр на поверхностях M и N обозначим (в обоих случаях) через u. Пусть параметрические пространства поверхностей имеют вид
для поверхности и
для поверхности Без ограничения общности будем считать, что Тогда поверхность перехода от M к N может быть описана формулой поверхности Эрмита:
где - местный параметр по направлению Данная поверхность Эрмита гладко сопрягает поверхности M и N по заданным краям. Класс гладкости сопряжения
Пример 6.3.4. Приклейка ручки с помощью поверхности перехода:
In[22] := Style [Module [{v, rl, r2, s1, s2 , drl, dr2 , dsl, ds2 , r, s}, r1[u_, v_] : = {-3 + (7 + 1.5 Cos [2 π u]) Sin [2 π v + π] , 1.5 Sin [2 π u] , {7 + 1.5 Cos [2 π u]) Cos [2 π v + π] } ; (*тор, u и v в пределах [0,1]*) r2 [u_, y_] := {5 Cos [2 π u] * Sin [π (v - 1) ] , 5 Sin [2 π] * Sin [π (v - 1) ] , 5 Cos [π {v - 1) ] } ; {*сфера, u в пределах [0,1], v в пределах [1,2]*) drl[t_] :=D[rl[t, v], v] * (7 / 6 - (1/2-1/10)) /.v -> l/2-l/10; dr2[t_] := D[r2[t, v] , v] * (7 / 6 - (1/2-1/10)) / . v -> 7 / 6; r[t_, w_] :=rl[fc, 1/2-1/10] (l- 3 w2 + 2 w3) + r2[t, 7/6] (з w2 - 2 w3) + drl[t] (w- 2 w2 + w3) + dr2[t] (-w2 + w3 ) ; sl[u_, v_] :=r2[u, v + 2] ; (* u в пределах [0,1], v в пределах [-1,0]*) s2[u_, v_] :=rl[u, v] ; dsl[t_] := D[sl[t, v] , v] * (1/10 + 1 / 6) /. v -> -1/ 6; ds2[t_] :=D[s2[t, v], v] * (1 / 10 + 1 / 6) / . v -> 1 / 10; s[t_, w_] :=sl[t, -1/6] (l- 3 w2 + 2 w3) + s2[t, 1/10] (з w2 - 2 w3) + dsl[t] (w- 2 w2 + w3) + ds2[fc] (-w2 + w3 ) ; Manipulate[Show[{ PararaetricPlot3D[rl[u, v] , {u, 0, 1} , {v, 1/10, 1 /2 - 1 / 10} , PlotStyle -> FaceForm[Orange, Blue]], PararaetricPlot3D[r2[u, v] , {u, 0,1}, {v, 1 + 1/6, 1+5/6}, PlotStyle -> FaceForm[Orange, Blue]], ParametricPlot3D[r [t, w] , {t, 0, 1}, {w, 0, wl}, PlotStyle -> FaceForm [Orange, Blue]], ParametricPlot3D [s [t, w] , {t, 0, 1}, {w, 0,w2}, PlotStyle -> FaceForm[Orange, Blue]] }, PlotRange -> {{-12, 10}, {-10, 10}, {-10, 10}}, Axes -> False, Boxed -> False ] , {{wl, 1} , 0.001, 1}, {{w2, 0.001}, 0.001, 1}, TrackedSymbols -> {wl, w2}, SaveDefinitions -> True, ControlPlacement -> Lef t] 1 , Magnification -> 2]