嗨,我想绘制火箭轨迹,它给了我一个错误:float()参数必须是字符串或数字,而不是'function'。我想绘制一个失去质量以获得推力的火箭的整个轨迹。当燃料结束时,它描述了一个抛物线轨迹。可以更改问题的数据。这就是我所说的值,其中mo是火箭的初始质量,q是气体的流量(质量如何随时间变化),g是重力加速度,xo是初始位置,t是时间。
我的代码是:
import math
import numpy as np
import matplotlib.pyplot as plt
%matplotlib inline
数据:
mo = 1500
q = 2.5
u = 6000
vo = 0
g = 9.8
x0 = 0
t = np.arange(0,1001)
t
速度执行:
def v(t):
return vo + u*(math.log(mo/(mo-q*t))-g*t)
位置执行:
def x(t):
return x0 + vo*t - 0.5*g*t^2 + u*t*math.log(mo) + (u/q)*((mo - q*t)*math.log(mo - q*t) + q*t - mo*math.log(mo))
for t in (0,100):
plt.plot(x,t)
plt.grid()
谢谢你帮我,我真的很感激。
应该是
而不是
上面要做的是将每个(x,y)视为一组数据。这是不正确的,因为这是您的数据集
((0, x(0)), (1, x(1))...)
的集合。一种可读的方法是为x轴和y轴创建一个数组:有四个问题。
x(t)
。math
。而是使用numpy
。**
,而不是^
。正确的代码可能如下所示:
生产
相关问题 更多 >
编程相关推荐