如何用Python绘制多个3dcurves图片?

2024-09-30 20:18:58 发布

您现在位置:Python中文网/ 问答频道 /正文

我想用Python在同一幅画上画两条空间曲线。你知道吗

所以,我使用two Axes3D.plot来绘制曲线。但最终的图片只显示了最后一张。如果我使用Axes3D.scatter,它可以显示所有点。你知道吗

这是我的代码:

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


t=2  #t can be changed

fig = plt.figure()
ax=Axes3D(fig)

#data

def unitilize(x,y,z):
    r=mt.sqrt(x**2+y**2+z**2)
    return x/r, y/r, z/r

def g_1(x,y,z):
    x=t*x                
    z=z/t                
    x,y,z=unitilize(x,y,z)
    return x,y,z

stepCnt=10000            ######step 
#########data#################
xs = np.empty((stepCnt + 1,))
ys = np.empty((stepCnt + 1,))
zs = np.empty((stepCnt + 1,))

#Setting initial values
def huatu(x,y,z):   

    xs[0], ys[0], zs[0] =unitilize(x,y,z)

    for i in range(stepCnt):
        xs[i+1],ys[i+1],zs[i+1]=g_1(xs[i], ys[i], zs[i])
    return xs,ys,zs


xs3,ys3,zs3=huatu(1,10,40)
ax.plot(xs3, ys3, zs3, color='b', marker='x')

xs2,ys2,zs2=huatu(1,0,40)
ax.plot(xs2, ys2, zs2, color='r', marker='o')

enter image description here


Tags: importreturnplotdefasnpaxempty
1条回答
网友
1楼 · 发布于 2024-09-30 20:18:58

在您的图像中,它看起来像蓝线在那里,但它隐藏在红线后面(您可以看到从红色圆圈中伸出的蓝色角)。尝试更改蓝线中的数据,您应该能够看到它。你知道吗

相关问题 更多 >