Main Page
Namespaces
Classes
Files
File List
test
mechanism_controllers
test_base_odomx_gt.py
Go to the documentation of this file.
1
#!/usr/bin/env python
2
# Software License Agreement (BSD License)
3
#
4
# Copyright (c) 2008, Willow Garage, Inc.
5
# All rights reserved.
6
#
7
# Redistribution and use in source and binary forms, with or without
8
# modification, are permitted provided that the following conditions
9
# are met:
10
#
11
# * Redistributions of source code must retain the above copyright
12
# notice, this list of conditions and the following disclaimer.
13
# * Redistributions in binary form must reproduce the above
14
# copyright notice, this list of conditions and the following
15
# disclaimer in the documentation and/or other materials provided
16
# with the distribution.
17
# * Neither the name of the Willow Garage nor the names of its
18
# contributors may be used to endorse or promote products derived
19
# from this software without specific prior written permission.
20
#
21
# THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
22
# "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
23
# LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS
24
# FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE
25
# COPYRIGHT OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT,
26
# INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING,
27
# BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;
28
# LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER
29
# CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
30
# LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN
31
# ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
32
# POSSIBILITY OF SUCH DAMAGE.
33
#
34
35
## Gazebo test base controller vw
36
37
PKG =
'pr2_gazebo'
38
NAME =
'test_base_odomx_gt'
39
40
import
math
41
import
roslib
42
roslib.load_manifest(PKG)
43
44
import
sys, unittest
45
import
os, time
46
import
rospy, rostest
47
48
from
geometry_msgs.msg
import
Twist,Vector3
49
from
nav_msgs.msg
import
Odometry
50
51
TEST_DURATION = 10.0
52
53
TARGET_VX = 0.25
54
TARGET_VY = 0.0
55
TARGET_VW = 0.0
56
TARGET_DURATION = 2.0
57
TARGET_TOL = 0.2
58
59
from
test_base
import
BaseTest, E, Q
60
class
X_GT
(
BaseTest
):
61
def
__init__
(self, *args):
62
super(X_GT, self).
__init__
(*args)
63
64
def
test_base
(self):
65
self.
init_ros
(NAME)
66
timeout_t =
None
67
while
not
rospy.is_shutdown()
and
not
self.
success
and
( timeout_t
is
None
or
time.time() < timeout_t ) :
68
#do not start commanding base until p3d and odom are initialized
69
if
self.
p3d_initialized
==
True
and
self.
odom_initialized
==
True
:
70
self.pub.publish(Twist(Vector3(TARGET_VX,TARGET_VY, 0), Vector3(0,0,TARGET_VW)))
71
if
timeout_t
is
None
:
# initialize timeout_t when p3d and odom is received
72
timeout_t = time.time() + TEST_DURATION
73
time.sleep(0.1)
74
#self.debug_pos()
75
# display what the odom error is
76
print
" error "
+
" x: "
+ str(self.
odom_x
- self.
p3d_x
) +
" y: "
+ str(self.
odom_y
- self.
p3d_y
) +
" t: "
+ str(self.
odom_t
- self.
p3d_t
)
77
78
# check total error
79
total_error = abs(self.
odom_x
- self.
p3d_x
) + abs(self.
odom_y
- self.
p3d_y
) + abs(self.
odom_t
- self.
p3d_t
)
80
if
total_error < TARGET_TOL:
81
self.
success
=
True
82
83
self.assert_(self.
success
)
84
85
if
__name__ ==
'__main__'
:
86
rostest.run(PKG, sys.argv[0], X_GT, sys.argv)
#, text_mode=True)
87
88
test_base_odomx_gt.X_GT
Definition:
test_base_odomx_gt.py:60
test_base.BaseTest.odom_y
odom_y
Definition:
test_base.py:104
test_base.BaseTest.odom_t
odom_t
Definition:
test_base.py:105
test_base.BaseTest.p3d_t
p3d_t
Definition:
test_base.py:116
test_base.BaseTest.success
success
Definition:
test_base.py:95
test_base.BaseTest.p3d_initialized
p3d_initialized
Definition:
test_base.py:112
test_base_odomx_gt.X_GT.__init__
def __init__(self, args)
Definition:
test_base_odomx_gt.py:61
msg
test_base.BaseTest.odom_x
odom_x
Definition:
test_base.py:103
test_base.BaseTest
Definition:
test_base.py:92
test_base.BaseTest.p3d_x
p3d_x
Definition:
test_base.py:114
test_base.BaseTest.odom_initialized
odom_initialized
Definition:
test_base.py:101
test_base.BaseTest.p3d_y
p3d_y
Definition:
test_base.py:115
test_base.BaseTest.init_ros
def init_ros(self, name)
Definition:
test_base.py:209
test_base_odomx_gt.X_GT.test_base
def test_base(self)
Definition:
test_base_odomx_gt.py:64
pr2_gazebo
Author(s): John Hsu
autogenerated on Mon Jun 10 2019 14:28:51