MSc in Robotics
Programming Methods for Robotics Assignment
Irene Moulitsas & Peter Sherar
Cranfield University
Hand in date: 17/01/20 (FT), 31/01/20 (PT), 2:00pm
1. Introduction
In this assignment you are asked to write and test some C++ code for performing filtering operations
that can be applied to digital images. Some existing image handling code is made available to you
through Blackboard.
Background
Suppose we are given an image, and we can access each pixel in the natural way, that is, using two
coordinates [x, y] (row x, column y). Each pixel is a combination of three colours: Red, Green, and Blue,
each colour represented by an integer value from 0 to 255. (0 means complete absence of the colour,
255 means the colour participates with full intensity.)
For this assignment you are going to use a particular image format called ppm.
The ppm image format consists of a header followed by the image pixel data. The header contains the
following information:
1. A number which indicates the type of storage used for the pixel values of the image. If the
number is P3 it means that the pixel data is stored in ascii text format which is a seven bit
代写MSc留学生作业、Programming课程作业代
character code. Each byte of an ascii text file is interpreted as one ascii character.
If the number is P6 it means that the pixel data is stored in compressed binary format following
the header. Here all eight bits of each byte are used.
2. Optional comment which begins with the # tag.
3. Width, height and maximum colour value of the image (usually 255)
The pixel data that follows consists of RGB values in the range 0-maximum colour value
Example ppm file
The following data represents an ASCII ppm image for a 200 by 200 pixel red box:
P3
#RedBox.ppm
200 200
255
255 0 0 255 0 0 255 0 0 255 0 0 255 0 0 255 0 0 255 0 0 255 0 0 255 0 0 255 0 0
255 0 0 255 0 0 255 0 0 255 0 0 255 0 0 255 0 0 255 0 0 255 0 0 255 0 0 255 0 0
255 0 0 255 0 0 255 0 0 255 0 0 255 0 0 255 0 0 255 0 0 255 0 0 255 0 0 255 0 0
255 0 0 255 0 0 255 0 0 255 0 0 255 0 0 255 0 0 255 0 0 255 0 0 255 0 0 255 0 0
….
and so on for a total of 4,000 rows.
Applying a filter to an image
Suppose we want to "sharpen" an image. What we need to do is "pass a filter" over every pixel in the
image. For example, a sharpening filter could be the following:
To pass this filter over the image means the following: For every pixel [x, y] of the image consider first
its red-value component. This will be an integer between 0 and 255, as explained above -- call it R for
ease of reference. Now imagine that R is placed at the centre of the 3x3 filter shown above, i.e., at the
location of number 9. Multiply R by 9. Now do the same for each horizontal, vertical, and diagonal
neighbour of pixel [x, y], that is, take the pixel [x-1, y-1] and multiply its red-value component by -1
(because that is the value in the corresponding location in the filter); same for pixels [x, y-1], [x+1, y-
1], [x-1, y], and so on. Finally, sum up these nine products. The result is the red-value component of
the new ("filtered") pixel. Do the same for the green and blue components, and you have the whole
pixel of the new image. If the values are less than zero, you make them zero; and if they are over 255,
you make them 255. This procedure can be repeated for every pixel of the original image except the
ones at the very edge (first & last row, leftmost & rightmost column); you ignore those pixels and copy
them directly from the original image.
The three filtering operations relevant for the assignment are the following:
Smooth
Smoothing is an operation used to reduce noise within an image or to produce a less pixelated image. A filter
for smoothing an image is as follows:
Sharpen
Sharpening an image Increases contrast and accentuates detail in the image or selection, but may also
accentuate noise. The filter below uses appropriate weighting factors to replace each pixel with a weighted
average of the 3x3 neighbourhood:
0 1 0
1 0 1
0 1 0
-1 -1 -1
-1 9 -1
-1 -1 -1
Edge Detection
An edge detector highlights sharp changes in intensity in the active image or selection. Two 3x3 convolution
kernels (shown below) are used to generate vertical and horizontal derivatives. The final image is produced by
combining the two derivatives using the square root of the sum of the squares.
The final integer RGB values are computed by rounding the square root value obtained to the nearest
integer.
vertical filter horizontal filter

2. Tasks
You are provided with the following code:
1. A Pixel class with implementation for reading, writing, setting and getting, and a few other
operations on RGB values.
2. The following 3 image functions for reading, writing and converting ppm files in binary to
ascii format:
/* opens a binary ppm file for reading and opens an asci ppm file
for writing */
void openIOFiles(ifstream& fin, ofstream& fout,
char inputFilename[]);
/* converts a binary image data file to P3 ascii format */
void convertP6ToP3(ifstream& bin, ofstream& out,
vector<vector<Pixel> >& image, int info[1]);
/* write P3 header and image data to a file */
void writeP3Image(ofstream& out, vector<vector<Pixel> >& image,
char comment[], int maxColor);
There are also three helper functions used by the above image functions:
/* reads binary image data and writes asci image data (called from
convertP6ToP3) */
void readAndWriteImageData(ifstream& fin, ofstream& fout,
vector<vector<Pixel> >& image, int w, int h);
/* reads the header from a ppm file (called from convertP6ToP3) */
void readHeader(ifstream& fin, ofstream& fout, int imageInfo[]);
/* writes the header for a ppm file (called from readHeader and
writeP3Image) */
void writeHeader(ofstream& fout, char magicNumber[], char comment[],
int w, int h, int maxPixelVal);
The filtering functions to write are:
void smooth(vector<vector<Pixel> >& image);
void sharpen(vector<vector<Pixel> >& image);
void edgeDetection(vector<vector<Pixel> >& image);
Using the functions provided and the above filtering functions, you also need to write a main
function which should perform the following sequence of operations:
• Open the binary ppm image file
• Convert the binary file to P3 format
• Perform the filtering operation on the pixel data
• Write the P3 image file containing the filtered pixel values
Test your code on the images provided in Blackboard within the “images” folder.
3. Source Code and Report Requirements
The source program will need to compile on the IT lab machines using Visual Studio 2017 or 2019
without any other external dependencies/libraries/source codes of third parties. Alternatively, the
source program will need to compile on the IT lab machines Linux partition using the Intel compiler,
without any other external dependencies/libraries/source codes of third parties, and you will need to
include a README file with clear compilation and execution instructions.
Write a report to present and discuss your findings. The report should be no less than 2,000 words
and must not exceed 3,000 words. The report can contain any number of figures/tables, however all
figures/tables should be numbered and discussed. The report should include a description of your
implementation explaining the method used. The source code should be included as an Appendix to
the report.
4. Assignment Submission
The source code files should be submitted electronically via the Blackboard submission point by 2:00
pm on 17
th January (full-time students) or the 31st January (part-time students).
The report should be submitted electronically via the TurnItInUK submission point by the prescribed
deadline, for the assignment submission to be considered complete.
5. Marking
The assignment will be assessed based on the following marking scheme:
• 20% Introduction, methodology, conclusions
• 40% Source code, commenting
• 30% Analysis of the results
• 10% Report structure, presentation, references

因为专业,所以值得信赖。如有需要,请加QQ:99515681 或 微信:codehelp

MSc in Robotics的更多相关文章

  1. How to build the Robotics Library from source code on Windows

    The Robotics Library is an open source C++ library for robot kinematics, motion planning and control ...

  2. Coursera Robotics系列课心得

    Robotics Perception Professor Kostas and Jianbo Shi week 1: camera model 凸透镜成像原理:凸透镜焦点与焦距是固定的,这是物理性质 ...

  3. MMC不能打开文件D:\Program Files\Microsoft SQL Server\80\Tools\BINN\SQL Server Enterprise Manager.MSC

    以上问题的解决方式如下: 1. 打开windows运行对话框.在对话框输入mmc.打开了如图所示的控制台. 2. 文件---添加/删除管理单元(M). 3. 添加.然后选择Microsoft SQL ...

  4. Learning ROS for Robotics Programming - Second Edition(《学习ROS机器人编程-第二版》)

    Learning ROS for Robotics Programming - Second Edition <学习ROS机器人编程-第二版> ----Your one-stop guid ...

  5. Microsoft Robotics Developer Studio 4

    Microsoft Robotics Developer Studio 4       Share   Language: English   Download Microsoft® Robotics ...

  6. JBoss 系列九十六:JBoss MSC - 简介及一个简单演示样例

    什么是 JBoss MSC JBoss MSC 即 JBoss Modular Service Container,是第三代 JBoss 产品 JBoss 7和WildFfly的内核,JBoss MS ...

  7. windows中.msc文件详解

    msc是Microsoft Management Console的缩写.其实是一种可执行程序类型,可.exe类似.一般可以通过直接双击.msc文件或者在windows的运行中输入相应的文件名来启动. ...

  8. Oracle 数据的导入和导出(SID service.msc)

    一:版本号说明: (1)(Oracle11  32位系统)Oracle - OraDb11g_home1: (2)成功安装后显演示样例如以下:第一个图是管理工具.创建连接.创建表:第二个是数据库创建工 ...

  9. 2014 International Conference on Robotics and Computer Vision (ICRVC 2014)

    2014机器人与计算机视觉国际会议ICRVC 与会地点:北京 与会时间:2014.10.24-26 截稿日期:2014-07-10 关于征稿: 语言:英文 主题: • Evolutionary Rob ...

随机推荐

  1. mysql8.0 caching_sha2_password的坑

    先来解释一下为什么会报这个错,在mysql8之前的版本使用的密码加密规则是mysql_native_password,但是在mysql8则是caching_sha2_password. 解决方案有很多 ...

  2. MQTT的Res接口发布消息

    MQTT(这里采用的V2版本)发布消息的常见方法: 1.通过MQTT客户端连接MQTT服务器,建立长连接,通过接口发布消息 最常见的客户端: <dependency> <groupI ...

  3. 利用nginx搭建文件服务器

    1.安装nginx 安装教程:https://www.cnblogs.com/sunny1009/p/11411673.html 2.配置nginx 配置server节点下的location部分和se ...

  4. Codeforces Round #604 (Div. 2) (题解)

    A. Beautiful String (暴力) 题目链接 题目大意: 给定一个字符串,只有 \(?a\ b\ c\ ?\) ,问是否存在一种将所有的 \(?\) 替换成 \(a\ b\ c\) ,使 ...

  5. a++与++a,谈谈C++的参数传递

    先看一段代码: #include<iostream> using namespace std; void func(int a, int b) { cout << a < ...

  6. 【题解】Luogu P5338 [TJOI2019]甲苯先生的滚榜

    原题传送门 这题明显可以平衡树直接大力整,所以我要说一下线段树+树状数组的做法 实际线段树+树状数组的做法也很暴力 我们先用树状数组维护每个ac数量有多少个队伍.这样就能快速求出有多少队伍ac数比现在 ...

  7. vuex的Store简单使用过程

    介绍 Store的代码结构一般由State.Getters.Mutation.Actions这四种组成,也可以理解Store是一个容器,Store里面的状态与单纯的全局变量是不一样的,无法直接改变st ...

  8. ELK学习笔记之logstash的各个场景应用(配置文件均已实践过)

    详细请参考该文 https://www.cnblogs.com/qingqing74647464/p/9378385.html

  9. Mysql批量更新的三种方式

    前言 批量插入由于mysql的VALUES原生支持,使用较为便利. 批量更新的写法一般有三种,在更新数量较少的情况下,前两种性能不相上下.但是在更新字段增加,更新条数较多(500以上)建议使用第三种写 ...

  10. XEN与VMware ESXi、Hyper-V 以及 KVM 架构与特点比较【非原创】

    XEN与VMware ESXi.Hyper-V 以及 KVM 架构与特点比较 2018年06月03日 12:47:15 Kim_Weir 阅读数 9402收起 分类专栏: 云计算   版权声明:本文为 ...