首页
网站开发
桌面应用
管理软件
微信开发
App开发
嵌入式软件
工具软件
数据采集与分析
其他
首页
>
> 详细
代做CSC477、代写Python,C++设计编程
项目预算:
开发周期:
发布时间:
要求地区:
CSC477 – Introduction To Mobile Robotics
assignment 1, 15 points due: Jan 31, 2024, at 6pm ET
Overview: In this assignment you will write a feedback controller that enables a ground robot, which obeys differential drive dynamics, to follow a wall. The purpose of this assignment is to make you develop experience with the following concepts:
Robot Operating System: its architecture and its publisher-subscriber model, which abstracts away the details of distributed computation and message passing from the robot programmer. Familiarity will also be developed with ROS’s main visualization tool, called rviz.
Controlling the yaw of a ground robot via PID control
Processing 2D laser measurements
The gazebo simulator, which is currently one of the most popular simulators in the robotics community.
Setting up VNC:
If you are planning on using the lab machines for this assignment, you will have to use VNC to access the lab PCs since you will need a GUI to run the simulations. If you plan on working from your local machine please skip this section and go to ”Setting Up ROS”.
We have posted a shared google spreadsheet containing the assignment of MCS lab machines to students, so please refer to Quercus for instructions on how to get a lab PC for yourself, if you need one. You can also work from your own machine, but note the requirements for setting up ROS, listed in the following sections. We might not be able to provide support or advice for the starter code if you run it on machines that do not satisfy those specs.
VNC is already installed on all the systems, but you need to set up your credentials so you can run your own VNC server that only you can access.
1. ssh into your account on your assigned lab PC
2. Type vncpasswd to create a password for yourself to access the PC
3. run vncserver with the following command so it creates the required directories.
vncserver
4. Then kill the server with
vncserver -kill :*
5. Use your favourite text editor to open the .vnc/xstartup file and put the following text in it:
#!/bin/sh
unset SESSION_MANAGER
exec /etc/X11/xinit/xinitrc
6. Now start a vncserver again with the same command:
vncserver
page 1 of 10
CSC477: Introduction to Mobile Robotics - Assignment 1 Jan 18, 2024
7. In the output of the command you just ran, make note of the :1 (or whatever number it is, it will be :x where x is an integer)
Here is an example of the output where the x=2 :
UTORid@dh2026pc09:~$ vncserver
New ’dh2026pc09.utm.utoronto.ca:2 (UTORid)’ desktop at :2 on machine dh2026pc09.utm.utoronto.ca
Starting applications specified in /student/UTORid/.vnc/xstartup
Log file is /student/UTORid/.vnc/dh2026pc09.utm.utoronto.ca:2.log
Use xtigervncviewer -SecurityTypes VncAuth -passwd /student/UTORid/.vnc/passwd :2 to
connect to the VNC server.
Now on your desktop:
1. Install a vncviewer (I installed realvnc-vnc-viewer but I think any one will work)
2. Start an ssh tunnel which the vncserver will go through. We are doing this because the vnc connection by itself is not encrypted and insecure, so its important that all the packets for your vnc connection pass through the secure ssh tunnel. To start the tunnel use the command:
ssh -L yyyy:localhost:590x -C UTORid@[your assigned lab pc].utm.utoronto.ca
where yyyy is a port you want to use on your workstation that is not already used. And x is the :x number that is shown to you when you started vncserver. The ’-C’ is to allow compression, it should help your remote instance be more responsive.
3. Once you log in, leave the window open and start the vncviewer on your local pc. The address you would be connecting to would be
localhost:yyyy
4. It will prompt for the vncpasswd that you created, and you should see your desktop.
If you run into trouble at any of the above steps, you may want to go through the relevant sections of the following VNC guides to see if they solve your problem before you ask for help.
For Ubuntu 18:
www.digitalocean.com/community/tutorials/how-to-install-and-configure-vnc-on-ubuntu-18-04
For Ubuntu 20:
www.digitalocean.com/community/tutorials/how-to-install-and-configure-vnc-on-ubuntu-20-04
For Ubuntu 22:
www.digitalocean.com/community/tutorials/how-to-install-and-configure-vnc-on-ubuntu-22-04
For Mac OS and Windows:
www.linode.com/docs/applications/remote-desktop/install-vnc-on-ubuntu-18-04/
page 2 of 10
CSC477: Introduction to Mobile Robotics - Assignment 1 Jan 18, 2024
Setting up ROS: There are multiple ways to install ROS. If you are planning to work from the MCS lab machines in Deerfield Hall (e.g. DH2020, DH2010, DH2026), Ubuntu and ROS are already installed and available to you. If you want to work from your own machine, we are assuming that you are running Ubuntu 20.04 on a computer which you have sudo access, then please make sure the following are installed:
Ubuntu 20.04. NOTE: Ubuntu 22.04 is by default not compatible with precompiled ROS 1 noetic packages, so it will not work. Compiling ROS noetic from source should work, but it is quite a long process, and it is not recommended. If you have Ubuntu 22.04 on your personal desktop then you might need to follow these instructions to install ROS 1 precompiled packages https://robostack. github.io/index.html, but we have not tested this. If this does not work, you might need to run ROS nodes inside a Docker container, as shown here https://roboticseabass.com/2021/04/21/ docker-and-ros/.
ROS 1 (noetic) http://wiki.ros.org/noetic/Installation/Ubuntu. If you have trouble installing ROS 1 please post on Piazza.
ROS 1 simulation dependencies (if you didn’t do a full install of ROS you can get them from sudo apt-get install ros-noetic-simulators)
any video screen recorder for assignment submission (e.g. recordmydesktop https://wiki.ubuntu.com/ScreenCasts/RecordMyDesktop)
Get and run the starter code: We have created a few simulated worlds consisting of sequences of walls and a simulated ground robot for you for the purposes of this assignment. A screenshot of the what the Gazebo simulation environment looks like is shown in Fig 1.
CSC477: Introduction to Mobile Robotics - Assignment 1 Jan 18, 2024
Figure 1: Gazebo environment with walls only on one side of the robot.
We are also providing starter code for this assignment. This starter code is provided in the form of ROS packages in your workspace. Make sure the following lines are at the end of your /home/[username]/.bashrc file:
export ROS_HOME=~/.ros
source /opt/ros/noetic/setup.bash
source ~/csc477_ws/devel/setup.bash
Then run the following command, this adds the paths to catkin and ros for your bash terminal, allowing you to use them
source ~/.bashrc
Then actually create your workspace:
mkdir -p ~/csc477_ws/src
cd ~/csc477_ws/src
catkin_init_workspace
In csc477 ws/src download the starter code:
git clone https://github.com/florianshkurti/csc477_winter24.git
Then compile it, but you have to run catkin make twice, as it fails the first time :
cd ~/csc477_ws
catkin_make
source ~/.bashrc
page 4 of 10
CSC477: Introduction to Mobile Robotics - Assignment 1 Jan 18, 2024
If this last command results in errors, you might need to install additional packages. Please post your questions on Piazza if this is the case and you don’t know what to do. In the MCS lab machines this will most likely not be an issue. If you are working from a personal laptop or desktop, however, you might need to install the following packages:
sudo apt-get install ros-noetic-control-toolbox ros-noetic-joystick-drivers
sudo apt-get install ros-noetic-realtime-tools ros-noetic-ros-control
sudo apt-get install ros-noetic-ros-controllers ros-noetic-gazebo-ros-control
If you still get errors after installing them please post a question on Quercus or email us as soon as possible. If compilation goes smoothly, move on to the following.
Your assignment is run using 3 commands, each in their own separate terminal. First you create the simulation environment, then you populate it with a virtual husky robot, and finally you run your code piloting the husky around the environment. This is what the commands look like at a glance, they are explained in further detail, and with some more setup info + checks below:
roslaunch wall_following_assignment gazebo_world.launch world_name:=[world_name]
roslaunch wall_following_assignment husky_follower.launch
roslaunch wall_following_assignment wall_follower_[language].launch
Here is a step-by-step walkthrough of the commands: Bring up a world with walls in the gazebo simulator
roslaunch wall_following_assignment gazebo_world.launch world_name:=walls_one_sided
Bring up the robot (husky) in that world
roslaunch wall_following_assignment husky_follower.launch
The only error that should appear after these two commands is that no joystick can be found. If another error is printed, please let us know. If these two commands go well this should make the gazebo image in Fig 1 shown above appear. Then, call rviz, which is the default visualization system for ROS:
rosrun rviz rviz
And then go to File > Open config and select the config file
csc477 ws/src/wall following assignment/resources/csc477.rviz You should see what’s shown in Fig 2:
The rainbow-colored line is actually a set of points detected by the simulated 2D laser. The other line and frames represent the tree of reference frames that the system is aware of. If all of this goes well then you will be ready to proceed to the next section, which is the essence of the assignment, and to write your controller code to make the robot move. At this point, you can run a simple last check:
rosrun teleop_twist_keyboard teleop_twist_keyboard.py \
cmd_vel:=/husky_1/husky_velocity_controller/cmd_vel
This command bring up a node publishing on topic /husky 1/husky velocity controller/cmd vel and enable you to control the robot through keyboard. If you can successfully move husky around using the keyboard through the command-line interface shown in Fig. 3 then you are ready to proceed with writing your PID controller.
Implement and test a wall-following controller (15 pts) The input to the robot will be laser scan messages from the robot’s simulated laser scanner. See here http://docs.ros.org/api/sensor_msgs/ html/msg/LaserScan.html for the ROS message definition. Also, make sure you have understood these ROS tutorials about the publisher-subscriber model of distributed computing: http://wiki.ros.org/ROS/ Tutorials. We have provided starter code for Python and C++ in the files
page 5 of 10
CSC477: Introduction to Mobile Robotics - Assignment 1 Jan 18, 2024
Figure 2: Rviz visualization for the Husky robot in Fig 1. Overlaid on the robot you can see the various reference frames from ROS’s tf system.
csc477_ws/src/csc477_fall22/wall_following_assignment/python/wall_follower.py
csc477_ws/src/csc477_fall22/wall_following_assignment/src/wall_follower_node.cpp
csc477_ws/src/csc477_fall22/wall_following_assignment/include/wall_following_assignment/pid.h
Choose your language and edit the appropriate files. Specifically:
[Part A, 2 pts] Compute the cross-track error based on each incoming laser scan and publish it un- der the topic name /husky 1/cte with the ROS message type std msgs/Float32, which can be found here http://wiki.ros.org/std_msgs. Tutorials for how to write your own publisher in Python can be found at http://wiki.ros.org/ROS/Tutorials/WritingPublisherSubscriber%28python%29.
[Part B, 7 pts] Populate the PID class based on the provided API. For each incoming laser scan is- sue an angular velocity command to the robot at the topic /husky velocity controller/cmd vel, based on the output of the PID controller. You need to follow the wall on the LEFT of the robot, as it is placed in its initial configuration.
[Part C, 2 pts]
Create a dynamic reconfigure server for tweaking your controller’s parameters in real time. Follow the in- structions presented here: http://wiki.ros.org/dynamic_reconfigure/Tutorials. Dong forget to make your cfg file executable, according to the instructions above. Add at least three parameters for the PID gains and run
rosrun rqt_reconfigure rqt_reconfigure
to tweak the PID parameters manually. A set of parameters is considered good enough and the run is considered successful if the robot does not collide with the wall and completes at least 3/4 of a full circuit around the left wall. NOTE: If you have build or import errors during this part let us know on Piazza.
page 6 of 10
CSC477: Introduction to Mobile Robotics - Assignment 1 Jan 18, 2024
Figure 3: Command-line interface for the node teleop twist keyboard.py which allows you to drive the robot using your keyboard. If you can do this successfully then you are ready to proceed with designing the controller.
page 7 of 10
CSC477: Introduction to Mobile Robotics - Assignment 1 Jan 18, 2024
[Part D, 4 pts] For each of the two simple wall worlds in wall following assignment/worlds/, namely: walls one sided.world, walls two sided.world, do the following:
Launch your wall following controller like this:
roslaunch wall_following_assignment wall_follower_python.launch
or
roslaunch wall_following_assignment wall_follower_cpp.launch
according to your language of choice.
(1pt/world) Use a desktop recording program such as recordMyDesktop or something similar to record a video of your robot while it is following the wall. Be sure to include any failure cases.
(1pt/world) Record the cross-track error published by your node as follows: rosbag record /husky_1/cte
and after your robot’s run is done, convert the recorded messages in the bag into a text file like so:
rostopic echo -b file.bag -p /husky_1/cte > cross_track_error.csv
rosbag play file.bag
[Optional Part E, 1 bonus pt] Implement and evaluate the PID self-tuning algorithm that was mentioned in class. Plot the cross-track error as a function of epochs (or iterations), where an epoch is a round of evaluation of a PID parameter setting on the simulator.
[Optional Part F, 2 bonus pts] Evaluate your wall-following ROS node on one of the real racecars that we have available for this course at UTM, shown here:
Note that these racecars as well as a technician to support their operation are only available at UTM. If you are interested in completing this bonus question, please reach out to our robotics lab technician at UTM, Ruthrash Hari (ruthrash.hari@mail.utoronto.ca).
Submission Instructions Assignment submissions will be done on Quercus. You will submit a zip file containing the following:
1. Your csc477 winter24/wall following assignment directory for Parts A, B, and C.
2. Two videos, one for demonstrating the robot’s navigation in the world walls one sided.world and another video for the world walls two sided.world as explained in Part D. The videos should be named as follows:
FirstName_LastName_StudentNumber_walls_one_sided.[mp4/avi]
FirstName_LastName_StudentNumber_walls_two_sided.[mp4/avi]
Each video should not exceed 10MB.
3. Similarly, two csv files from Part D. They should be named:
page 8 of 10
CSC477: Introduction to Mobile Robotics - Assignment 1 Jan 18, 2024
Figure 4: CSC477 Racecar
FirstName_LastName_StudentNumber_walls_one_sided.csv
FirstName_LastName_StudentNumber_walls_two_sided.csv
The point of including a video of your controller in your submission is not just for us to easily examine your code. It’s also so that you can easily show your work later on to classmates/coworkers/employers. It becomes part of your portfolio. It is also worth noting that, due to the ROS abstraction layer, if you want, you could run your feedback controller on a real Husky robot, without major modifications.
4. If you’ve done the optional bonus question E, please submit the resulting figure as:
FirstName_LastName_StudentNumber_bonus_question_PID_autotuning.[png/jpg]
5. If you’ve done the optional bonus question F, please submit a video (under 20MB) showing the racecar doing wall-following on the 3rd floor of Deerfield Hall at UTM:
FirstName_LastName_StudentNumber_bonus_question_Racecar.[mp4/avi]
We expect your code to run on the MCS Lab machines. If it does not you will lose marks. We expect to be able to compile it using catkin make. Once we compile your code we will run the following:
roslaunch wall_following_assignment gazebo_world.launch world_name:=[world_name]
roslaunch wall_following_assignment husky_follower.launch
roslaunch wall_following_assignment wall_follower_[language].launch
page 9 of 10
CSC477: Introduction to Mobile Robotics - Assignment 1 Jan 18, 2024
We will test your code on other similar worlds to the one provided. We will also test it using different desired distances away from the goal. The default desired distance is 1 meter away, and the default forward speed is 1m/s. We will test your code with different parameters in that neighbourhood. Your code will also be examined for correctness, style and efficiency. We recommend that you come by during office hours or email us if you are unsure of your implementation.
软件开发、广告设计客服
QQ:99515681
邮箱:99515681@qq.com
工作时间:8:00-23:00
微信:codinghelp
热点项目
更多
代写dts207tc、sql编程语言代做
2024-12-25
cs209a代做、java程序设计代写
2024-12-25
cs305程序代做、代写python程序...
2024-12-25
代写csc1001、代做python设计程...
2024-12-24
代写practice test preparatio...
2024-12-24
代写bre2031 – environmental...
2024-12-24
代写ece5550: applied kalman ...
2024-12-24
代做conmgnt 7049 – measurem...
2024-12-24
代写ece3700j introduction to...
2024-12-24
代做adad9311 designing the e...
2024-12-24
代做comp5618 - applied cyber...
2024-12-24
代做ece5550: applied kalman ...
2024-12-24
代做cp1402 assignment - netw...
2024-12-24
热点标签
mktg2509
csci 2600
38170
lng302
csse3010
phas3226
77938
arch1162
engn4536/engn6536
acx5903
comp151101
phl245
cse12
comp9312
stat3016/6016
phas0038
comp2140
6qqmb312
xjco3011
rest0005
ematm0051
5qqmn219
lubs5062m
eee8155
cege0100
eap033
artd1109
mat246
etc3430
ecmm462
mis102
inft6800
ddes9903
comp6521
comp9517
comp3331/9331
comp4337
comp6008
comp9414
bu.231.790.81
man00150m
csb352h
math1041
eengm4100
isys1002
08
6057cem
mktg3504
mthm036
mtrx1701
mth3241
eeee3086
cmp-7038b
cmp-7000a
ints4010
econ2151
infs5710
fins5516
fin3309
fins5510
gsoe9340
math2007
math2036
soee5010
mark3088
infs3605
elec9714
comp2271
ma214
comp2211
infs3604
600426
sit254
acct3091
bbt405
msin0116
com107/com113
mark5826
sit120
comp9021
eco2101
eeen40700
cs253
ece3114
ecmm447
chns3000
math377
itd102
comp9444
comp(2041|9044)
econ0060
econ7230
mgt001371
ecs-323
cs6250
mgdi60012
mdia2012
comm221001
comm5000
ma1008
engl642
econ241
com333
math367
mis201
nbs-7041x
meek16104
econ2003
comm1190
mbas902
comp-1027
dpst1091
comp7315
eppd1033
m06
ee3025
msci231
bb113/bbs1063
fc709
comp3425
comp9417
econ42915
cb9101
math1102e
chme0017
fc307
mkt60104
5522usst
litr1-uc6201.200
ee1102
cosc2803
math39512
omp9727
int2067/int5051
bsb151
mgt253
fc021
babs2202
mis2002s
phya21
18-213
cege0012
mdia1002
math38032
mech5125
07
cisc102
mgx3110
cs240
11175
fin3020s
eco3420
ictten622
comp9727
cpt111
de114102d
mgm320h5s
bafi1019
math21112
efim20036
mn-3503
fins5568
110.807
bcpm000028
info6030
bma0092
bcpm0054
math20212
ce335
cs365
cenv6141
ftec5580
math2010
ec3450
comm1170
ecmt1010
csci-ua.0480-003
econ12-200
ib3960
ectb60h3f
cs247—assignment
tk3163
ics3u
ib3j80
comp20008
comp9334
eppd1063
acct2343
cct109
isys1055/3412
math350-real
math2014
eec180
stat141b
econ2101
msinm014/msing014/msing014b
fit2004
comp643
bu1002
cm2030
联系我们
- QQ: 9951568
© 2021
www.rj363.com
软件定制开发网!