Advertisement
luizaspan

Colisão unidimensional /não acabado nem testado III

May 19th, 2015
316
0
Never
Not a member of Pastebin yet? Sign Up, it unlocks many cool features!
C 0.70 KB | None | 0 0
  1. / método de euler para EDOs:
  2. // f(x+dx) = f(x) + dxF(f,x) (+ condição inicial)
  3.      
  4. // EDO Colisão unidimensional (elástica)
  5.      
  6. #include <stdio.h>
  7.      
  8. #define dt 0.00001
  9. #define v01 -30
  10. #define v02 10
  11. #define m1 5
  12. #define m2 8
  13.      
  14. int main(void)
  15. {
  16.   int i;
  17.   double v1,v2,t,x1,x2;
  18.      
  19.   x1=15;
  20.   x2=5;
  21.  
  22.   v1=v01;
  23.   v2=v02;
  24.      
  25.   for (i=0;i<2e5;i++)
  26.     {
  27.       t=++i*dt;
  28.      
  29.       x1+=v1*dt;
  30.       x2+=v2*dt;
  31.      
  32.       if (x1==x2 || x1-x2<=2.) //tentar módulo
  33.     {
  34.       v1=((m1-m2)/(m1+m2))*v01+ ((2*m2)/(m1+m2))*v02;
  35.       v2=((2*m1)/(m1+m2))*v01-((m1-m2)/(m1+m2))*v02;
  36.     }
  37.       printf("%lf\t %lf\t %lf\t %lf\t %lf\n",t,x1,x2,v1,v2);
  38.     }
  39.      
  40.   return 0;
  41. }
Advertisement
Add Comment
Please, Sign In to add comment
Advertisement