Математический регионПлот на поверхности единичной сферы?
Я использую RegionPlot3D
в Mathematica для визуализации некоторых неравенств. Поскольку неравенства однородны в координатах, они однозначно определяются их пересечением с единичной сферой. Это дает некоторые двумерные области на поверхности сферы, которые я хотел бы построить. Мой вопрос как?
Если потребуется, я был бы более чем счастлив предоставить некоторый код Mathematica; хотя я считаю, что ответ должен быть независимым от деталей регионов, которые я пытаюсь построить.
Спасибо заранее!
Обновление. Если кто-то заинтересован, я недавно закончил работу, в которой я использовал Сашу ниже, чтобы сделать некоторые сюжеты. Бумага Симметричные фоны M-теории и была получена на прошлой неделе. Он содержит графики, такие как этот:
![F-moduli space for a symmetric M-theory background]()
Еще раз спасибо!
Ответы
Ответ 1
Посмотрите RegionFunction
. Вы можете использовать свои неравенства в нем внутри ParametricPlot3D
.
Show[{ParametricPlot3D[{Sin[th] Cos[ph], Sin[th] Sin[ph],
Cos[th]}, {th, 0, Pi}, {ph, 0, 2 Pi},
RegionFunction ->
Function[{x, y, z}, And[x^3 < x y z + z^3, y^2 z < y^3 + x z^2]],
PlotRange -> {-1, 1}, PlotStyle -> Red],
Graphics3D[{Opacity[0.2], Sphere[]}]}]
![enter image description here]()
Ответ 2
Вот простейшая идея, которую я мог бы придумать (благодаря belisarius для некоторого кода).
- Проецируем неравенства на сферу с использованием сферических координат (с θ = q, φ = f).
- Разделите их как плоский участок.
- Затем нарисуйте это как текстуру сферы.
Здесь пара однородных неравенств порядка 3
ineq = {x^3 < x y^2, y^2 z > x z^2};
coords = {x -> r Sin[q] Cos[f], y -> r Sin[q] Sin[f], z -> r Cos[q]}/.r -> 1
region = RegionPlot[ineq /. coords, {q, 0, Pi}, {f, 0, 2 Pi},
Frame -> None, ImagePadding -> 0, PlotRangePadding -> 0, ImageMargins -> 0]
![flat region]()
ParametricPlot3D[coords[[All, 2]], {q, 0, Pi}, {f, 0, 2 Pi},
Mesh -> None, TextureCoordinateFunction -> ({#4, 1 - #5} &),
PlotStyle -> Texture[Show[region, ImageSize -> 1000]]]
![animation]()
Ответ 3
Симон избил меня до удара, но здесь похожая идея, основанная на графике более низкого уровня. Я имею дело с линейными однородными неравенствами вида Ах > 0.
A = RandomReal[{0, 1}, {8, 3}];
eqs = And @@ Thread[
A.{Sin[phi] Cos[th], Sin[phi] Sin[th], Cos[phi]} >
Table[0, {Length[A]}]];
twoDPic = RegionPlot[eqs,
{phi, 0, Pi}, {th, 0, 2 Pi}];
pts2D = twoDPic[[1, 1]];
spherePt[{phi_, th_}] := {Sin[phi] Cos[th], Sin[phi] Sin[th],
Cos[phi]};
rpSphere = Graphics3D[GraphicsComplex[spherePt /@ pts2D,
twoDPic[[1, 2]]]]
Сравним его с RegionPlot3D
.
rp3D = RegionPlot3D[And @@ Thread[A.{x, y, z} >
Table[0, {Length[A]}]],
{x, -2, 2}, {y, -2, 2}, {z, -2, 2},
PlotStyle -> Opacity[0.2]];
Show[{rp3D, rpSphere}, PlotRange -> 1.4]
Ответ 4
SphericalPlot3D[0.6, {\[Phi], 0, \[Pi]}, {\[Theta], 0, 2 \[Pi]},
RegionFunction ->
Function[{x, y, z},
PolyhedronData["Cube", "RegionFunction"][x, y, z]], Mesh -> False,
PlotStyle -> {Orange, Opacity[0.9]}]