| Keywords: mathematica 3d cg parametricplot3d texture torus knot 輪環 りんかん ドーナツ どーなつ 結び むすび 捩れ よじれ プログラム コード code program algorithm コード アルゴリズム geometric sculpture geometricsculpture shape geometry sculpture mapping テクスチャ マッピング 模様 もよう abstract 抽象 ちゅうしょう アブストラクト design pattern デザイン パターン graphic グラフィック グラフィクス structure 意匠 構造 symmetry 対称性 たいしょうせい シンメトリー 対称 たいしょう algorithm bright a = 4; (* center hole size of a torus *) b1 = 5; (* number of cross *) b2 = 3; (* number of cross *) c = 0; (* distance from the center of rotation *) SetOptions[ParametricPlot3D, PlotRange -> Full, Mesh -> None,    Boxed -> False, Axes -> None, PlotPoints -> 300, ImageSize -> 1600,    Background -> Darker[Green, 0.8],    PlotStyle -> Directive[Specularity[White, 90], Texture[Import["D:/tmp/861.jpg"]]],    TextureCoordinateFunction -> ({#4 + #5, #5 / Pi} &), Lighting -> "Neutral"];  g[v_] := Sum[Cos[(2 k - 1) v]/(2 k - 1), {k, 4}]; x = (a - g[t] + Sin[b1 s]) Cos[b2 s] + c; y = (a - g[t] + Sin[b1 s]) Sin[b2 s] + c; z = Sin[b1 (s + Pi)] + Sin[t] + c;  ParametricPlot3D[{x, y, z}, {t, 0, 2 Pi}, {s, 0, 2 Pi}]  (*---  The Texture is this: www.flickr.com/photos/tanaka_juuyoh/5412528282/ *)   a = 4; (* center hole size of a torus *) b1 = 5; (* number of cross *) b2 = 3; (* number of cross *) c = 0; (* distance from the center of rotation *) SetOptions[ParametricPlot3D, PlotRange -> Full, Mesh -> None,    Boxed -> False, Axes -> None, PlotPoints -> 300, ImageSize -> 1600,    Background -> Darker[Green, 0.8],    PlotStyle -> Directive[Specularity[White, 90], Texture[Import["D:/tmp/861.jpg"]]],    TextureCoordinateFunction -> ({#4 + #5, #5 / Pi} &), Lighting -> "Neutral"];  g[v_] := Sum[Cos[(2 k - 1) v]/(2 k - 1), {k, 4}]; x = (a - g[t] + Sin[b1 s]) Cos[b2 s] + c; y = (a - g[t] + Sin[b1 s]) Sin[b2 s] + c; z = Sin[b1 (s + Pi)] + Sin[t] + c;  ParametricPlot3D[{x, y, z}, {t, 0, 2 Pi}, {s, 0, 2 Pi}]  (*---  The Texture is this: www.flickr.com/photos/tanaka_juuyoh/5412528282/ *) |