Как соединить эти две 3D -линии вместе с поверхностью в матплотлибе PythonPython

Программы на Python
Ответить Пред. темаСлед. тема
Anonymous
 Как соединить эти две 3D -линии вместе с поверхностью в матплотлибе Python

Сообщение Anonymous »

У меня есть два орбиты, которые встречаются на разных высотах. Я планирую их в 3D, но я хочу объединить их вместе с поверхностью. До сих пор у меня есть эта картина:
< /p>

, который я получаю, использую этот скрипт: < /p>

import numpy as np
import matplotlib
import matplotlib.pyplot as plt
from mpl_toolkits.mplot3d import Axes3D

font = {'size' : 18}
matplotlib.rc('font', **font)

fig = plt.figure()
ax = fig.add_subplot(111, projection='3d')

#Read in data
data = np.genfromtxt('mu8.txt')
x, y = np.hsplit(data, 2)
N = len(x)
z = np.zeros(N)
z[:,] = 8.0

#Plot the first orbit
ax.plot(x, y, z, 'k-', linewidth=3.0)

#Read in data for second orbit
data = np.genfromtxt('mu9.txt')
x2, y2 = np.hsplit(data, 2)
N = len(x2)
z2 = np.zeros(N)
z2[:,] = 9.0

#Plot second orbit
ax.plot(x2, y2, z2, 'k-', linewidth=3.0)

#Join together the data for both orbits
xx = np.concatenate((x, x2), axis=0)
yy = np.concatenate((y, y2), axis=0)
zz = np.concatenate((z, z2), axis=0)

#Plot the surface
surf = ax.plot_surface(xx,yy,zz, color='m', alpha=0.3,
linewidth=0)

#Set axis and things
ax.set_xticks([1.0,1.5,2])
ax.set_yticks([32,35,38])
ax.set_ylabel('$||u||_{2}$', fontsize=26, rotation=0, labelpad = 26)
ax.set_xlabel('$h$', fontsize=26)
ax.set_zlabel('$\mu$', fontsize=26, rotation=90)
plt.tight_layout()

plt.show()
< /code>

Как вы видите - это выглядит не очень хорошо. Моя мотивация к желанию сделать это состоит в том, что у меня есть гораздо больше этих орбит, которые мне нужно построить, все они на разных высотах. По мере изменения высоты орбиты становятся меньше. Я чувствую лучший способ визуализировать это - присоединиться к ним с поверхностью - таким образом, орбиты проследят деформированный цилиндр с двумя стволами, который в конце сжимается и ущипнут. Есть ли способ сделать это? < /p>

Я хотел бы иметь возможность что -то сделать в стиле этого:


Подробнее здесь: https://stackoverflow.com/questions/325 ... matplotlib
Реклама
Ответить Пред. темаСлед. тема

Быстрый ответ

Изменение регистра текста: 
Смайлики
:) :( :oops: :roll: :wink: :muza: :clever: :sorry: :angel: :read: *x)
Ещё смайлики…
   
К этому ответу прикреплено по крайней мере одно вложение.

Если вы не хотите добавлять вложения, оставьте поля пустыми.

Максимально разрешённый размер вложения: 15 МБ.

  • Похожие темы
    Ответы
    Просмотры
    Последнее сообщение

Вернуться в «Python»