Я строю график движения снаряда без/с трением о воздух, и сейчас я работаю над первой частью, то есть без трения о воздух.
После того, как я поставил plt.plot(x_nodrag,y_nodrag), он должен нарисовать кривую линию движения снаряда. Но по некоторым причинам он не рисуется, даже когда данные о них печатаются. Я хочу знать, почему.
Я знаю, что в этом коде может быть много ошибок!! Не стесняйтесь указывать на них, если хотите. Спасибо, ребята, за помощь.
Вот картинка графика:https://i.stack.imgur.com/znFLM.png
import numpy as np
import matplotlib.pyplot as plt
# Model parameters
M = 1.0 # Mass of projectile in kg
g = 9.8 # Acceleration due to gravity (m/s^2)
V = 80 # Initial velocity in m/s
ang = 60.0 # Angle of initial velocity in degree
Cd = 0.005 # Drag coefficient
dt = 0.5 # time step in s
# Set up the lists to store variables
# Start by putting the initial velocities at t=0
t = [0] # list to keep track of time
vx = [V*np.cos(ang/180*np.pi)] # list for velocity x and y components
vy = [V*np.sin(ang/180*np.pi)]
#show the projectile motion without drag force
t1=0
vx_nodrag=V*np.cos(ang/180*np.pi)
vy_nodrag=V*np.sin(ang/180*np.pi)
while (t1 < 100):
x_nodrag=vx_nodrag*t1
y_nodrag=vy_nodrag*t1+(0.5*-9.8*t1**2)
plt.ylim([0,200])
plt.xlim([0,270])
plt.plot(x_nodrag,y_nodrag)
print(x_nodrag,y_nodrag)
t1=t1+dt
plt.show()
Команда plt.plot
не работает для отдельных точек. Вместо этого используйте plt.scatter(x_nodrag, y_nodrag)
или соберите последовательные координаты в списки или массивы, а затем сразу постройте весь график.
plt.plot
будет работать, если fmt
заменить на '.'
; независимо scatter
имеет больше смысла
Вы должны смотреть на анимацию.