annotate python/extrapolation.py @ 242:942455aff829

merged with the addition of Mohamed's code
author Nicolas Saunier <nicolas.saunier@polymtl.ca>
date Fri, 13 Jul 2012 17:30:25 -0400
parents d2b68111f87e
children e0988a8ace0c
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
240
d2b68111f87e added module for extrapolation
Sarah@Sarah-PC.polymtl.ca
parents:
diff changeset
1 ##########
d2b68111f87e added module for extrapolation
Sarah@Sarah-PC.polymtl.ca
parents:
diff changeset
2 # Extrapolation Hypothesis
d2b68111f87e added module for extrapolation
Sarah@Sarah-PC.polymtl.ca
parents:
diff changeset
3 ##########
d2b68111f87e added module for extrapolation
Sarah@Sarah-PC.polymtl.ca
parents:
diff changeset
4
d2b68111f87e added module for extrapolation
Sarah@Sarah-PC.polymtl.ca
parents:
diff changeset
5 import sys
d2b68111f87e added module for extrapolation
Sarah@Sarah-PC.polymtl.ca
parents:
diff changeset
6
d2b68111f87e added module for extrapolation
Sarah@Sarah-PC.polymtl.ca
parents:
diff changeset
7 sys.path.append("G:/0-phdstart/Code/traffic-intelligence1/python")
d2b68111f87e added module for extrapolation
Sarah@Sarah-PC.polymtl.ca
parents:
diff changeset
8
d2b68111f87e added module for extrapolation
Sarah@Sarah-PC.polymtl.ca
parents:
diff changeset
9 import moving
d2b68111f87e added module for extrapolation
Sarah@Sarah-PC.polymtl.ca
parents:
diff changeset
10
d2b68111f87e added module for extrapolation
Sarah@Sarah-PC.polymtl.ca
parents:
diff changeset
11 #Default values
d2b68111f87e added module for extrapolation
Sarah@Sarah-PC.polymtl.ca
parents:
diff changeset
12 FPS= 25 # No. of frame per second (FPS)
d2b68111f87e added module for extrapolation
Sarah@Sarah-PC.polymtl.ca
parents:
diff changeset
13 vLimit= 25/FPS #assume limit speed is 90km/hr = 25 m/sec
d2b68111f87e added module for extrapolation
Sarah@Sarah-PC.polymtl.ca
parents:
diff changeset
14 deltaT= FPS*5 # extrapolatation time Horizon = 5 second
d2b68111f87e added module for extrapolation
Sarah@Sarah-PC.polymtl.ca
parents:
diff changeset
15
d2b68111f87e added module for extrapolation
Sarah@Sarah-PC.polymtl.ca
parents:
diff changeset
16 def ExtrapolationPosition (movingObject1, instant,deltaT):
d2b68111f87e added module for extrapolation
Sarah@Sarah-PC.polymtl.ca
parents:
diff changeset
17 ''' extrapolation hypothesis: constant velocity'''
d2b68111f87e added module for extrapolation
Sarah@Sarah-PC.polymtl.ca
parents:
diff changeset
18 return movingObject1.getPositionAtInstant(instant) + movingObject1.getVelocityAtInstant(instant). multiply(deltaT)
d2b68111f87e added module for extrapolation
Sarah@Sarah-PC.polymtl.ca
parents:
diff changeset
19
d2b68111f87e added module for extrapolation
Sarah@Sarah-PC.polymtl.ca
parents:
diff changeset
20 def motion (position, velocity, acceleration):
d2b68111f87e added module for extrapolation
Sarah@Sarah-PC.polymtl.ca
parents:
diff changeset
21 ''' extrapolation hypothesis: constant acceleration'''
d2b68111f87e added module for extrapolation
Sarah@Sarah-PC.polymtl.ca
parents:
diff changeset
22 from math import atan2,cos,sin
d2b68111f87e added module for extrapolation
Sarah@Sarah-PC.polymtl.ca
parents:
diff changeset
23 vInit= velocity
d2b68111f87e added module for extrapolation
Sarah@Sarah-PC.polymtl.ca
parents:
diff changeset
24 vInitial= velocity.norm2()
d2b68111f87e added module for extrapolation
Sarah@Sarah-PC.polymtl.ca
parents:
diff changeset
25 theta= atan2(velocity.y,velocity.x)
d2b68111f87e added module for extrapolation
Sarah@Sarah-PC.polymtl.ca
parents:
diff changeset
26 vFinal= vInitial+acceleration
d2b68111f87e added module for extrapolation
Sarah@Sarah-PC.polymtl.ca
parents:
diff changeset
27
d2b68111f87e added module for extrapolation
Sarah@Sarah-PC.polymtl.ca
parents:
diff changeset
28 if acceleration<= 0:
d2b68111f87e added module for extrapolation
Sarah@Sarah-PC.polymtl.ca
parents:
diff changeset
29 v= max(0,vFinal)
d2b68111f87e added module for extrapolation
Sarah@Sarah-PC.polymtl.ca
parents:
diff changeset
30 velocity= moving.Point(v* cos(theta),v* sin(theta))
d2b68111f87e added module for extrapolation
Sarah@Sarah-PC.polymtl.ca
parents:
diff changeset
31 position= position+ (velocity+vInit). multiply(0.5)
d2b68111f87e added module for extrapolation
Sarah@Sarah-PC.polymtl.ca
parents:
diff changeset
32 else:
d2b68111f87e added module for extrapolation
Sarah@Sarah-PC.polymtl.ca
parents:
diff changeset
33 v= min(vLimit,vFinal)
d2b68111f87e added module for extrapolation
Sarah@Sarah-PC.polymtl.ca
parents:
diff changeset
34 velocity= moving.Point(v* cos(theta),v* sin(theta))
d2b68111f87e added module for extrapolation
Sarah@Sarah-PC.polymtl.ca
parents:
diff changeset
35 position= position+ (velocity+vInit). multiply(0.5)
d2b68111f87e added module for extrapolation
Sarah@Sarah-PC.polymtl.ca
parents:
diff changeset
36 return(position,velocity)
d2b68111f87e added module for extrapolation
Sarah@Sarah-PC.polymtl.ca
parents:
diff changeset
37
d2b68111f87e added module for extrapolation
Sarah@Sarah-PC.polymtl.ca
parents:
diff changeset
38 def motionPET (position, velocity, acceleration, deltaT):
d2b68111f87e added module for extrapolation
Sarah@Sarah-PC.polymtl.ca
parents:
diff changeset
39 ''' extrapolation hypothesis: constant acceleration for calculating pPET '''
d2b68111f87e added module for extrapolation
Sarah@Sarah-PC.polymtl.ca
parents:
diff changeset
40 from math import atan2,cos,sin,fabs
d2b68111f87e added module for extrapolation
Sarah@Sarah-PC.polymtl.ca
parents:
diff changeset
41 vInit= velocity
d2b68111f87e added module for extrapolation
Sarah@Sarah-PC.polymtl.ca
parents:
diff changeset
42 vInitial= velocity.norm2()
d2b68111f87e added module for extrapolation
Sarah@Sarah-PC.polymtl.ca
parents:
diff changeset
43 theta= atan2(velocity.y,velocity.x)
d2b68111f87e added module for extrapolation
Sarah@Sarah-PC.polymtl.ca
parents:
diff changeset
44 vFinal= vInitial+acceleration * deltaT
d2b68111f87e added module for extrapolation
Sarah@Sarah-PC.polymtl.ca
parents:
diff changeset
45 if acceleration< 0:
d2b68111f87e added module for extrapolation
Sarah@Sarah-PC.polymtl.ca
parents:
diff changeset
46 if vFinal> 0:
d2b68111f87e added module for extrapolation
Sarah@Sarah-PC.polymtl.ca
parents:
diff changeset
47 velocity= moving.Point(vFinal* cos(theta),vFinal* sin(theta))
d2b68111f87e added module for extrapolation
Sarah@Sarah-PC.polymtl.ca
parents:
diff changeset
48 position= position+ (vInit+ velocity). multiply(0.5*deltaT)
d2b68111f87e added module for extrapolation
Sarah@Sarah-PC.polymtl.ca
parents:
diff changeset
49 else:
d2b68111f87e added module for extrapolation
Sarah@Sarah-PC.polymtl.ca
parents:
diff changeset
50 T= fabs(vInitial/acceleration)
d2b68111f87e added module for extrapolation
Sarah@Sarah-PC.polymtl.ca
parents:
diff changeset
51 position= position + vInit. multiply(0.5*T)
d2b68111f87e added module for extrapolation
Sarah@Sarah-PC.polymtl.ca
parents:
diff changeset
52 elif acceleration> 0 :
d2b68111f87e added module for extrapolation
Sarah@Sarah-PC.polymtl.ca
parents:
diff changeset
53 if vFinal<= vLimit:
d2b68111f87e added module for extrapolation
Sarah@Sarah-PC.polymtl.ca
parents:
diff changeset
54 velocity= moving.Point(vFinal* cos(theta),vFinal* sin(theta))
d2b68111f87e added module for extrapolation
Sarah@Sarah-PC.polymtl.ca
parents:
diff changeset
55 position= position+ (vInit+ velocity). multiply(0.5*deltaT)
d2b68111f87e added module for extrapolation
Sarah@Sarah-PC.polymtl.ca
parents:
diff changeset
56 else:
d2b68111f87e added module for extrapolation
Sarah@Sarah-PC.polymtl.ca
parents:
diff changeset
57 time1= fabs((vLimit-vInitial)/acceleration)
d2b68111f87e added module for extrapolation
Sarah@Sarah-PC.polymtl.ca
parents:
diff changeset
58 velocity= moving.Point(vLimit* cos(theta),vLimit* sin(theta))
d2b68111f87e added module for extrapolation
Sarah@Sarah-PC.polymtl.ca
parents:
diff changeset
59 position= (position+ (velocity+vInit). multiply(0.5*time1)) + (velocity.multiply (deltaT-time1))
d2b68111f87e added module for extrapolation
Sarah@Sarah-PC.polymtl.ca
parents:
diff changeset
60 elif acceleration == 0:
d2b68111f87e added module for extrapolation
Sarah@Sarah-PC.polymtl.ca
parents:
diff changeset
61 position= position + velocity. multiply(deltaT)
d2b68111f87e added module for extrapolation
Sarah@Sarah-PC.polymtl.ca
parents:
diff changeset
62
d2b68111f87e added module for extrapolation
Sarah@Sarah-PC.polymtl.ca
parents:
diff changeset
63 return position
d2b68111f87e added module for extrapolation
Sarah@Sarah-PC.polymtl.ca
parents:
diff changeset
64
d2b68111f87e added module for extrapolation
Sarah@Sarah-PC.polymtl.ca
parents:
diff changeset
65 def timePET (position, velocity, acceleration, intersectedPoint ):
d2b68111f87e added module for extrapolation
Sarah@Sarah-PC.polymtl.ca
parents:
diff changeset
66 ''' extrapolation hypothesis: constant acceleration for calculating pPET '''
d2b68111f87e added module for extrapolation
Sarah@Sarah-PC.polymtl.ca
parents:
diff changeset
67 from math import atan2,cos,sin,fabs
d2b68111f87e added module for extrapolation
Sarah@Sarah-PC.polymtl.ca
parents:
diff changeset
68 vInit= velocity
d2b68111f87e added module for extrapolation
Sarah@Sarah-PC.polymtl.ca
parents:
diff changeset
69 vInitial= velocity.norm2()
d2b68111f87e added module for extrapolation
Sarah@Sarah-PC.polymtl.ca
parents:
diff changeset
70 theta= atan2(velocity.y,velocity.x)
d2b68111f87e added module for extrapolation
Sarah@Sarah-PC.polymtl.ca
parents:
diff changeset
71 vFinal= vInitial+acceleration * deltaT
d2b68111f87e added module for extrapolation
Sarah@Sarah-PC.polymtl.ca
parents:
diff changeset
72 if acceleration< 0:
d2b68111f87e added module for extrapolation
Sarah@Sarah-PC.polymtl.ca
parents:
diff changeset
73 if vFinal> 0:
d2b68111f87e added module for extrapolation
Sarah@Sarah-PC.polymtl.ca
parents:
diff changeset
74 velocity= moving.Point(vFinal* cos(theta),vFinal* sin(theta))
d2b68111f87e added module for extrapolation
Sarah@Sarah-PC.polymtl.ca
parents:
diff changeset
75 time= fabs((intersectedPoint.x-position.x)/(0.5*(vInit.x+ velocity.x)))
d2b68111f87e added module for extrapolation
Sarah@Sarah-PC.polymtl.ca
parents:
diff changeset
76 else:
d2b68111f87e added module for extrapolation
Sarah@Sarah-PC.polymtl.ca
parents:
diff changeset
77 time= fabs((intersectedPoint.x-position.x)/(0.5*(vInit.x)))
d2b68111f87e added module for extrapolation
Sarah@Sarah-PC.polymtl.ca
parents:
diff changeset
78 elif acceleration> 0 :
d2b68111f87e added module for extrapolation
Sarah@Sarah-PC.polymtl.ca
parents:
diff changeset
79 if vFinal<= vLimit:
d2b68111f87e added module for extrapolation
Sarah@Sarah-PC.polymtl.ca
parents:
diff changeset
80 velocity= moving.Point(vFinal* cos(theta),vFinal* sin(theta))
d2b68111f87e added module for extrapolation
Sarah@Sarah-PC.polymtl.ca
parents:
diff changeset
81 time= fabs((intersectedPoint.x-position.x)/(0.5*(vInit.x+ velocity.x)))
d2b68111f87e added module for extrapolation
Sarah@Sarah-PC.polymtl.ca
parents:
diff changeset
82 else:
d2b68111f87e added module for extrapolation
Sarah@Sarah-PC.polymtl.ca
parents:
diff changeset
83 time1= fabs((vLimit-vInitial)/acceleration)
d2b68111f87e added module for extrapolation
Sarah@Sarah-PC.polymtl.ca
parents:
diff changeset
84 velocity= moving.Point(vLimit* cos(theta),vLimit* sin(theta))
d2b68111f87e added module for extrapolation
Sarah@Sarah-PC.polymtl.ca
parents:
diff changeset
85 time2= fabs((intersectedPoint.x-position.x)/(0.5*(vInit.x+ velocity.x)))
d2b68111f87e added module for extrapolation
Sarah@Sarah-PC.polymtl.ca
parents:
diff changeset
86 if time2<=time1:
d2b68111f87e added module for extrapolation
Sarah@Sarah-PC.polymtl.ca
parents:
diff changeset
87 time= time2
d2b68111f87e added module for extrapolation
Sarah@Sarah-PC.polymtl.ca
parents:
diff changeset
88 else:
d2b68111f87e added module for extrapolation
Sarah@Sarah-PC.polymtl.ca
parents:
diff changeset
89 position2= (position+ (velocity+vInit). multiply(0.5*time1))
d2b68111f87e added module for extrapolation
Sarah@Sarah-PC.polymtl.ca
parents:
diff changeset
90 time= time1+fabs((intersectedPoint.x-position2.x)/( velocity.x))
d2b68111f87e added module for extrapolation
Sarah@Sarah-PC.polymtl.ca
parents:
diff changeset
91 elif acceleration == 0:
d2b68111f87e added module for extrapolation
Sarah@Sarah-PC.polymtl.ca
parents:
diff changeset
92 time= fabs((intersectedPoint.x-position.x)/(velocity.x))
d2b68111f87e added module for extrapolation
Sarah@Sarah-PC.polymtl.ca
parents:
diff changeset
93
d2b68111f87e added module for extrapolation
Sarah@Sarah-PC.polymtl.ca
parents:
diff changeset
94 return time
d2b68111f87e added module for extrapolation
Sarah@Sarah-PC.polymtl.ca
parents:
diff changeset
95
d2b68111f87e added module for extrapolation
Sarah@Sarah-PC.polymtl.ca
parents:
diff changeset
96 def motionSteering (position, velocity, deltaTheta, deltaT ):
d2b68111f87e added module for extrapolation
Sarah@Sarah-PC.polymtl.ca
parents:
diff changeset
97 ''' extrapolation hypothesis: steering with deltaTheta'''
d2b68111f87e added module for extrapolation
Sarah@Sarah-PC.polymtl.ca
parents:
diff changeset
98 from math import atan2,cos,sin
d2b68111f87e added module for extrapolation
Sarah@Sarah-PC.polymtl.ca
parents:
diff changeset
99 vInitial= velocity.norm2()
d2b68111f87e added module for extrapolation
Sarah@Sarah-PC.polymtl.ca
parents:
diff changeset
100 theta= atan2(velocity.y,velocity.x)
d2b68111f87e added module for extrapolation
Sarah@Sarah-PC.polymtl.ca
parents:
diff changeset
101 newTheta= theta + deltaTheta
d2b68111f87e added module for extrapolation
Sarah@Sarah-PC.polymtl.ca
parents:
diff changeset
102 velocity= moving.Point(vInitial* cos(newTheta),vInitial* sin(newTheta))
d2b68111f87e added module for extrapolation
Sarah@Sarah-PC.polymtl.ca
parents:
diff changeset
103 position= position+ (velocity). multiply(deltaT)
d2b68111f87e added module for extrapolation
Sarah@Sarah-PC.polymtl.ca
parents:
diff changeset
104 return position
d2b68111f87e added module for extrapolation
Sarah@Sarah-PC.polymtl.ca
parents:
diff changeset
105
d2b68111f87e added module for extrapolation
Sarah@Sarah-PC.polymtl.ca
parents:
diff changeset
106 def MonteCarlo(movingObject1,movingObject2, instant):
d2b68111f87e added module for extrapolation
Sarah@Sarah-PC.polymtl.ca
parents:
diff changeset
107 ''' Monte Carlo Simulation : estimate the probability of collision'''
d2b68111f87e added module for extrapolation
Sarah@Sarah-PC.polymtl.ca
parents:
diff changeset
108 from random import uniform
d2b68111f87e added module for extrapolation
Sarah@Sarah-PC.polymtl.ca
parents:
diff changeset
109 from math import pow, sqrt, sin, cos,atan2
d2b68111f87e added module for extrapolation
Sarah@Sarah-PC.polymtl.ca
parents:
diff changeset
110 N=1000
d2b68111f87e added module for extrapolation
Sarah@Sarah-PC.polymtl.ca
parents:
diff changeset
111 ProbOfCollision = 0
d2b68111f87e added module for extrapolation
Sarah@Sarah-PC.polymtl.ca
parents:
diff changeset
112 for n in range (1, N):
d2b68111f87e added module for extrapolation
Sarah@Sarah-PC.polymtl.ca
parents:
diff changeset
113 # acceleration limit
d2b68111f87e added module for extrapolation
Sarah@Sarah-PC.polymtl.ca
parents:
diff changeset
114 acc1 = uniform(-0.040444,0)
d2b68111f87e added module for extrapolation
Sarah@Sarah-PC.polymtl.ca
parents:
diff changeset
115 acc2 = uniform(-0.040444,0)
d2b68111f87e added module for extrapolation
Sarah@Sarah-PC.polymtl.ca
parents:
diff changeset
116 p1= movingObject1.getPositionAtInstant(instant)
d2b68111f87e added module for extrapolation
Sarah@Sarah-PC.polymtl.ca
parents:
diff changeset
117 p2= movingObject2.getPositionAtInstant(instant)
d2b68111f87e added module for extrapolation
Sarah@Sarah-PC.polymtl.ca
parents:
diff changeset
118 v1= movingObject1.getVelocityAtInstant(instant)
d2b68111f87e added module for extrapolation
Sarah@Sarah-PC.polymtl.ca
parents:
diff changeset
119 v2= movingObject2.getVelocityAtInstant(instant)
d2b68111f87e added module for extrapolation
Sarah@Sarah-PC.polymtl.ca
parents:
diff changeset
120 distance= (p1-p2).norm2()
d2b68111f87e added module for extrapolation
Sarah@Sarah-PC.polymtl.ca
parents:
diff changeset
121 distanceThreshold= 1.8
d2b68111f87e added module for extrapolation
Sarah@Sarah-PC.polymtl.ca
parents:
diff changeset
122 t=1
d2b68111f87e added module for extrapolation
Sarah@Sarah-PC.polymtl.ca
parents:
diff changeset
123 while distance > distanceThreshold and t <= deltaT:
d2b68111f87e added module for extrapolation
Sarah@Sarah-PC.polymtl.ca
parents:
diff changeset
124 # Extrapolation position
d2b68111f87e added module for extrapolation
Sarah@Sarah-PC.polymtl.ca
parents:
diff changeset
125 (p1,v1) = motion(p1,v1,acc1)
d2b68111f87e added module for extrapolation
Sarah@Sarah-PC.polymtl.ca
parents:
diff changeset
126 (p2,v2) = motion(p2,v2,acc2)
d2b68111f87e added module for extrapolation
Sarah@Sarah-PC.polymtl.ca
parents:
diff changeset
127 distance= (p1-p2).norm2()
d2b68111f87e added module for extrapolation
Sarah@Sarah-PC.polymtl.ca
parents:
diff changeset
128 if distance <=distanceThreshold:
d2b68111f87e added module for extrapolation
Sarah@Sarah-PC.polymtl.ca
parents:
diff changeset
129 ProbOfCollision= ProbOfCollision+1
d2b68111f87e added module for extrapolation
Sarah@Sarah-PC.polymtl.ca
parents:
diff changeset
130 t+=1
d2b68111f87e added module for extrapolation
Sarah@Sarah-PC.polymtl.ca
parents:
diff changeset
131 POC= float(ProbOfCollision)/N
d2b68111f87e added module for extrapolation
Sarah@Sarah-PC.polymtl.ca
parents:
diff changeset
132 return POC
d2b68111f87e added module for extrapolation
Sarah@Sarah-PC.polymtl.ca
parents:
diff changeset
133
d2b68111f87e added module for extrapolation
Sarah@Sarah-PC.polymtl.ca
parents:
diff changeset
134 def velocitySteering(velocity,steering):
d2b68111f87e added module for extrapolation
Sarah@Sarah-PC.polymtl.ca
parents:
diff changeset
135 from math import atan2,cos,sin
d2b68111f87e added module for extrapolation
Sarah@Sarah-PC.polymtl.ca
parents:
diff changeset
136 vInitial= velocity.norm2()
d2b68111f87e added module for extrapolation
Sarah@Sarah-PC.polymtl.ca
parents:
diff changeset
137 theta= atan2(velocity.y,velocity.x)
d2b68111f87e added module for extrapolation
Sarah@Sarah-PC.polymtl.ca
parents:
diff changeset
138 newTheta= theta + steering
d2b68111f87e added module for extrapolation
Sarah@Sarah-PC.polymtl.ca
parents:
diff changeset
139 v= moving.Point(vInitial* cos(newTheta),vInitial* sin(newTheta))
d2b68111f87e added module for extrapolation
Sarah@Sarah-PC.polymtl.ca
parents:
diff changeset
140 return v
d2b68111f87e added module for extrapolation
Sarah@Sarah-PC.polymtl.ca
parents:
diff changeset
141
d2b68111f87e added module for extrapolation
Sarah@Sarah-PC.polymtl.ca
parents:
diff changeset
142 def MonteCarloSteering(movingObject1,movingObject2, instant,steering1,steering2):
d2b68111f87e added module for extrapolation
Sarah@Sarah-PC.polymtl.ca
parents:
diff changeset
143 ''' Monte Carlo Simulation : estimate the probability of collision in case of steering'''
d2b68111f87e added module for extrapolation
Sarah@Sarah-PC.polymtl.ca
parents:
diff changeset
144 from random import uniform
d2b68111f87e added module for extrapolation
Sarah@Sarah-PC.polymtl.ca
parents:
diff changeset
145 from math import pow, sqrt, sin, cos,atan2
d2b68111f87e added module for extrapolation
Sarah@Sarah-PC.polymtl.ca
parents:
diff changeset
146 N=1000
d2b68111f87e added module for extrapolation
Sarah@Sarah-PC.polymtl.ca
parents:
diff changeset
147 L= 2.4
d2b68111f87e added module for extrapolation
Sarah@Sarah-PC.polymtl.ca
parents:
diff changeset
148 ProbOfCollision = 0
d2b68111f87e added module for extrapolation
Sarah@Sarah-PC.polymtl.ca
parents:
diff changeset
149 for n in range (1, N):
d2b68111f87e added module for extrapolation
Sarah@Sarah-PC.polymtl.ca
parents:
diff changeset
150 # acceleration limit
d2b68111f87e added module for extrapolation
Sarah@Sarah-PC.polymtl.ca
parents:
diff changeset
151 acc1 = uniform(-0.040444,0)
d2b68111f87e added module for extrapolation
Sarah@Sarah-PC.polymtl.ca
parents:
diff changeset
152 acc2 = uniform(-0.040444,0)
d2b68111f87e added module for extrapolation
Sarah@Sarah-PC.polymtl.ca
parents:
diff changeset
153 p1= movingObject1.getPositionAtInstant(instant)
d2b68111f87e added module for extrapolation
Sarah@Sarah-PC.polymtl.ca
parents:
diff changeset
154 p2= movingObject2.getPositionAtInstant(instant)
d2b68111f87e added module for extrapolation
Sarah@Sarah-PC.polymtl.ca
parents:
diff changeset
155 vInit1= movingObject1.getVelocityAtInstant(instant)
d2b68111f87e added module for extrapolation
Sarah@Sarah-PC.polymtl.ca
parents:
diff changeset
156 v1= velocitySteering (vInit1,steering1)
d2b68111f87e added module for extrapolation
Sarah@Sarah-PC.polymtl.ca
parents:
diff changeset
157 vInit2= movingObject2.getVelocityAtInstant(instant)
d2b68111f87e added module for extrapolation
Sarah@Sarah-PC.polymtl.ca
parents:
diff changeset
158 v2= velocitySteering (vInit2,steering2)
d2b68111f87e added module for extrapolation
Sarah@Sarah-PC.polymtl.ca
parents:
diff changeset
159 distance= (p1-p2).norm2()
d2b68111f87e added module for extrapolation
Sarah@Sarah-PC.polymtl.ca
parents:
diff changeset
160 distanceThreshold= 1.8
d2b68111f87e added module for extrapolation
Sarah@Sarah-PC.polymtl.ca
parents:
diff changeset
161 t=1
d2b68111f87e added module for extrapolation
Sarah@Sarah-PC.polymtl.ca
parents:
diff changeset
162 while distance > distanceThreshold and t <= deltaT:
d2b68111f87e added module for extrapolation
Sarah@Sarah-PC.polymtl.ca
parents:
diff changeset
163 # Extrapolation position
d2b68111f87e added module for extrapolation
Sarah@Sarah-PC.polymtl.ca
parents:
diff changeset
164 (p1,v1) = motion(p1,v1,acc1)
d2b68111f87e added module for extrapolation
Sarah@Sarah-PC.polymtl.ca
parents:
diff changeset
165 (p2,v2) = motion(p2,v2,acc2)
d2b68111f87e added module for extrapolation
Sarah@Sarah-PC.polymtl.ca
parents:
diff changeset
166 distance= (p1-p2).norm2()
d2b68111f87e added module for extrapolation
Sarah@Sarah-PC.polymtl.ca
parents:
diff changeset
167 if distance <=distanceThreshold:
d2b68111f87e added module for extrapolation
Sarah@Sarah-PC.polymtl.ca
parents:
diff changeset
168 ProbOfCollision= ProbOfCollision+1
d2b68111f87e added module for extrapolation
Sarah@Sarah-PC.polymtl.ca
parents:
diff changeset
169 t+=1
d2b68111f87e added module for extrapolation
Sarah@Sarah-PC.polymtl.ca
parents:
diff changeset
170 POC= float(ProbOfCollision)/N
d2b68111f87e added module for extrapolation
Sarah@Sarah-PC.polymtl.ca
parents:
diff changeset
171 return POC
d2b68111f87e added module for extrapolation
Sarah@Sarah-PC.polymtl.ca
parents:
diff changeset
172
d2b68111f87e added module for extrapolation
Sarah@Sarah-PC.polymtl.ca
parents:
diff changeset
173