forked from udacity/CarND-Capstone
-
Notifications
You must be signed in to change notification settings - Fork 4
/
dbw_node.py
executable file
·139 lines (110 loc) · 4.88 KB
/
dbw_node.py
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
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
#!/usr/bin/env python
import rospy
from std_msgs.msg import Bool
from dbw_mkz_msgs.msg import ThrottleCmd, SteeringCmd, BrakeCmd, SteeringReport
from geometry_msgs.msg import TwistStamped
import math
from twist_controller import Controller
'''
This node will subscribe:
'dbw_enabled' --------> Boolean value represent whether dbw is enabled.
'throttle_cmd' -------> Proposed linear and angular velocity.
'current_velocity' ---> Current vehicle velocity.
This node will publish:
'steering_cmd' -------> Steer angle.
'ThrottleCmd' --------> Accelerate value.
'BrakeCmd' -----------> Brake torque.
'''
PUBLISH_RATE = 50
GAS_DENSITY = 2.858
ONE_MPH = 0.44704
class VehicleParams(object):
# Define a class containing all vehicle parameters.
def __init__(self):
self.vehicle_mass = None
self.fuel_capacity = None
self.brake_deadband = None
self.decel_limit = None
self.accel_limit = None
self.wheel_radius = None
self.wheel_base = None
self.steer_ratio = None
self.max_lat_accel = None
self.max_steer_angle = None
self.total_vehicle_mass = None
class DBWNode(object):
# Define a class running dbw node.
def __init__(self):
rospy.init_node('dbw_node')
ego_params = VehicleParams()
ego_params.vehicle_mass = rospy.get_param('~vehicle_mass', 1736.35)
ego_params.fuel_capacity = rospy.get_param('~fuel_capacity', 13.5)
ego_params.brake_deadband = rospy.get_param('~brake_deadband', .1)
ego_params.decel_limit = rospy.get_param('~decel_limit', -5)
ego_params.accel_limit = rospy.get_param('~accel_limit', 1.)
ego_params.wheel_radius = rospy.get_param('~wheel_radius', 0.2413)
ego_params.wheel_base = rospy.get_param('~wheel_base', 2.8498)
ego_params.steer_ratio = rospy.get_param('~steer_ratio', 14.8)
ego_params.max_lat_accel = rospy.get_param('~max_lat_accel', 3.)
ego_params.max_steer_angle = rospy.get_param('~max_steer_angle', 8.)
ego_params.total_vehicle_mass = ego_params.vehicle_mass + ego_params.fuel_capacity * GAS_DENSITY
self.steer_pub = rospy.Publisher('/vehicle/steering_cmd', SteeringCmd, queue_size=1)
self.throttle_pub = rospy.Publisher('/vehicle/throttle_cmd', ThrottleCmd, queue_size=1)
self.brake_pub = rospy.Publisher('/vehicle/brake_cmd', BrakeCmd, queue_size=1)
# Create "Controller" object, will return throttle, brake, steering.
self.controller = Controller(vehicle_params=ego_params)
self.current_vel = None
self.curr_ang_vel = None
self.dbw_enabled = True
self.linear_vel = None
self.angular_vel = None
self.throttle = self.steering = self.brake = 0
# Subscribers
rospy.Subscriber('/vehicle/dbw_enabled', Bool, self.dbw_enabled_cb)
rospy.Subscriber('/twist_cmd', TwistStamped, self.twist_cb)
rospy.Subscriber('/current_velocity', TwistStamped, self.velocity_cb)
self.loop()
def loop(self):
'''
Calculate the upcoming throttle, brake, and steering information.
Publish the calculated information.
Calculation and publish information all based on the set rate (50Hz).
'''
rate = rospy.Rate(PUBLISH_RATE)
while not rospy.is_shutdown():
if not None in(self.current_vel, self.linear_vel, self.angular_vel):
self.throttle, self.brake, self.steering = self.controller.control(self.current_vel,
self.dbw_enabled,
self.linear_vel,
self.angular_vel)
if self.dbw_enabled:
self.publish(self.throttle, self.brake, self.steering)
rate.sleep()
def dbw_enabled_cb(self, msg):
self.dbw_enabled = msg
def twist_cb(self, msg):
self.linear_vel = msg.twist.linear.x
self.angular_vel = msg.twist.angular.z
def velocity_cb(self, msg):
self.current_vel = msg.twist.linear.x
def publish(self, throttle, brake, steer):
'''
Given throttle, brake, steer values,
publish these values through 'throttle_cmd', 'brake_cmd' ,'steering_cmd' separately.
'''
tcmd = ThrottleCmd()
tcmd.enable = True
tcmd.pedal_cmd_type = ThrottleCmd.CMD_PERCENT
tcmd.pedal_cmd = throttle
self.throttle_pub.publish(tcmd)
scmd = SteeringCmd()
scmd.enable = True
scmd.steering_wheel_angle_cmd = steer
self.steer_pub.publish(scmd)
bcmd = BrakeCmd()
bcmd.enable = True
bcmd.pedal_cmd_type = BrakeCmd.CMD_TORQUE
bcmd.pedal_cmd = brake
self.brake_pub.publish(bcmd)
if __name__ == '__main__':
DBWNode()