File: jcoaster.ode

package info (click to toggle)
xppaut 8.0%2Bdfsg-1
  • links: PTS, VCS
  • area: main
  • in suites: forky, sid
  • size: 7,332 kB
  • sloc: ansic: 74,690; makefile: 127; sh: 92
file content (80 lines) | stat: -rwxr-xr-x 2,081 bytes parent folder | download | duplicates (6)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
#Coaster demo showing how to use derivative and value matching to
#join two coaster tracks together. Note, we're use cubic splines 
#parametric in M to do this.
#
#Here's the MATLAB code to find the spline coefficients
#M1 = -2; %Specify your 1st join parametric point here.
#M2 = 2;  %Specify your 2nd join parametric point here.
#
#
#A = [1 M1 M1^2 M1^3;
#     0 1 2*M1 3*M1^2;
#     1 M2 M2^2 M2^3;
#     0 1 2*M2 3*M2^2];
#
#%These values and derivatives will depend 
#%on the track you set up.  Be careful to get
#%these right...   
#
#XRHS = [-2 1 2 1]';
#ZRHS = [4 2 0 0]'; 
#
#%Now solve for the matching parameters...
#Xs_par = A\XRHS
#Zs_par = A\ZRHS
#

#Hey, define your roller coaster track here!
#Use parametric equations in M.

#Parameters from our cubic spline matching solutions.
par xs0=0,xs1=1,xs2=0,xs3=0
par zs0=3,zs1=-2,zs2=-0.25,zs3=0.25

xM(M) = heav(-2-M)*(M) + (heav(M+2)-heav(M-2))*(xs0+xs1*M+xs2*(M^2)+xs3*(M^3)) + heav(M-2)*M
zM(M) = heav(-2-M)*(3+(M+3)^2) + (heav(M+2)-heav(M-2))*(zs0+zs1*M+zs2*(M^2)+zs3*(M^3)) + heav(M-2)*((M-2)^2)

#Now calculate and put the derivatives of your
#parametric equations here:

xMdM(M) = heav(-2-M)*(1) + (heav(M+2)-heav(M-2))*(xs1+2*xs2*M+3*xs3*(M^2)) + heav(M-2)*1
zMdM(M) = heav(-2-M)*(2*(M+3)) + (heav(M+2)-heav(M-2))*(zs1+2*zs2*M+3*zs3*(M^2)) + heav(M-2)*(2*(M-2))


param drag=.1
param mass=1
param g=8.3
# scale mouse velocity a little as it is too sensitive
par sv=.25
init M=-4,X=-4,Z=4
init L=0,Lalt=0

#Shouldn't need to modify too much below...

normM(M) = sqrt(xMdM(M)^2 + zMdM(M)^2)
mdt(M) = Lalt/normM(M)

dX/dt=xMdM(M)*mdt(M)
dZ/dt=zMdM(M)*mdt(M)
dM/dt=mdt(M)
dL/dt=Lalt
#Thanks to Newton!
dLalt/dt=(1/mass)*((-g*zMdM(M)/normM(M)) - drag*Lalt)

set Sun     {g=274.13} 	
set Mercury {g=3.59}	
set Venus   {g=8.87}    
set Earth   {g=9.81}    
set Moon    {g=1.62}    
set Mars    {g=3.77}   
set Jupiter {g=25.95}
set Saturn  {g=11.08}    
set Uranus  {g=10.67}    
set Neptune {g=14.07} 
set Pluto   {g=0.42}
 
@ XP=X,YP=Z,XLO=-6,XHI=4,YLO=0,YHI=6
@ bounds=100000,meth=r
@ dt=.01,nout=5
@ total=50
done