Como Hallar El Recorrido De Un Objeto Y El Área Bajo La Curva En Python - Gunook
Como Hallar El Recorrido De Un Objeto Y El Área Bajo La Curva En Python - Gunook
Anonim
Como Hallar El Recorrido De Un Objeto Y El Área Bajo La Curva En Python
Como Hallar El Recorrido De Un Objeto Y El Área Bajo La Curva En Python

Este programa gráfica la curva que existe entre la relación velocidad contra tiempo en el movimiento de un objeto. Además este programa calcula el recorrido que hizo este objeto al encontrar el área debajo de la curva que se gráfica.

Schritt 1: Haz Un Vídeo En Tracker Y Haz El Seguimiento

Haz Un Vídeo En Tracker Y Haz El Seguimiento
Haz Un Vídeo En Tracker Y Haz El Seguimiento
Haz Un Vídeo En Tracker Y Haz El Seguimiento
Haz Un Vídeo En Tracker Y Haz El Seguimiento

Erstellen Sie ein Video mit einem Filmobjekt. Haz el seguimiento de este y utiliza los datos de velocidad contra tiempo. Guarda esos datos como un archivo txt para utilizarlo posteriormente en el código.

Puede descargar este programa en el siguiente link:

Schritt 2: Importar E Instalar Librerías

Importar E Instalar Librerías
Importar E Instalar Librerías

Debes importar las librerías llamadas numpy und matplotlib.pyplot. Esto es porque sin ellas el código no funcionaría. Antes de importar estas librerías debes instalarlas. En Windows debes primero presionar el botón windows y el botón R. Aparecerá una ventana negra, debes escribir lo siguiente:

cd c:/python27/scripts

Presionas enter y luego debes decirle que instale las librerías de pip.

Este es el código que debes utilizar en el programa:

import numpy als npimport matplotlib.pyplot als plt

Schritt 3: Crea Una Variable Que Contenga Los Datos a Gráficar Y Añádelos a Una Lista

Crea Una Variable Que Contenga Los Datos a Gráficar Y Añádelos a Una Lista
Crea Una Variable Que Contenga Los Datos a Gráficar Y Añádelos a Una Lista

Usa una lista de datos (los datos que conseguiste en tracker). Esa lista debes asignarla a una variable para que se guarden. Luego esa variable añádela a dos listas, una para el eje x y otra para el eje y.

data=np.loadtxt("Datos tec.txt", float)x=data[0:1000, 0] y=data[0:1000, 1]

Schritt 4: Encuentra El Área

Encuentra El Área
Encuentra El Área

Para el área debes crear un for i in range. Debes limitarlo a el numero de datos que tienes. Luego al ser una curva, debes hacer que el programa calcule el área de trapecios pequeños y se sumen estas áreas. El área de un trapecio es sumando las dos bases, multiplicarla por la altura y dividendo en dos. Para que haga varios trapecios debes decir que se coja el dato inicial, que se sume el siguiente y se divida de 2. Luego ese valor multiplicarlo por el dato initial restado al dato siguiente. Esto lo debes anexar a una lista vacía que puedes llamar área.

area=für i in range(0, 10): area.append((((y[i+1]+y)/2)*(x[i+1]-x)))

Schritt 5: Imprime El Área

Imprime El Área
Imprime El Área

Para imprimir los resultados de tu área, debes imprimir la suma de cada área.

print "El recorrido fue de", sum(area), "metros"

Schritt 6: Gráfica Los Resultados

Gráfica Los Resultados
Gráfica Los Resultados

Para gráficar los resultados es muy sencillo. Debes escribir plt.plot y entre paréntesis las listas en las que tienes guardados los datos con los que vas a trabajar. Finalmente beschreibt plt.show para que se pueda visualizar la gráfica.

plt.plot(x, y, "r-")plt.fill_between(x, y) plt.show()

Schritt 7: Resultado Finale

Ergebnisado Finale
Ergebnisado Finale
Ergebnisado Finale
Ergebnisado Finale

El resultado final debería ser ähnlich einem esto. La gráfica depende del movimiento que estés analizando. Particularmente en este es un objeto cayendo, por lo que el resultado es negativo, pues el desplazamiento es negativo.

numpy als np importieren

import matplotlib.pyplot als plt

data=np.loadtxt("Datos tec.txt", float)

x=Daten[0:1000, 0] y=Daten[0:1000, 1]

Bereich=

für i im Bereich (0, 10): area.append((((y[i+1]+y)/2)*(x[i+1]-x)))

print "El recorrido fue de", sum(area), "metros"

plt.plot(x, y, "r-")

plt.fill_between(x, y) plt.show()

Empfohlen: