The latest instance of the course can be found at: O1: 2024
Luet oppimateriaalin englanninkielistä versiota. Mainitsit kuitenkin taustakyselyssä osaavasi suomea. Siksi suosittelemme, että käytät suomenkielistä versiota, joka on testatumpi ja hieman laajempi ja muutenkin mukava.
Suomenkielinen materiaali kyllä esittelee englanninkielisetkin termit. Myös suomenkielisessä materiaalissa käytetään ohjelmaprojektien koodissa englanninkielisiä nimiä kurssin alkupään johdantoesimerkkejä lukuunottamatta.
Voit vaihtaa kieltä A+:n valikon yläreunassa olevasta painikkeesta. Tai tästä: Vaihda suomeksi.
Chapter 8.1: Robots
About This Page
Questions Answered: Can I apply what I’ve learned on a larger program?
Topics: A particular simulator app. There are no new topics per se, but we will discuss a program that is more complex than any of the previous ones.
What Will I Do? Program.
Rough Estimate of Workload:? A couple of hours?
Points Available: B40.
Related Projects: Robots (new).
Introduction
Much of Week 8 revolves around a programming assignment in which you construct a robot simulator. In this simulator, a “robot world” is essentially a grid where “robots” of very little brain conduct their virtual existence.
The assignment has been broken down in eight parts. The first two are in this chapter; the rest are in Chapters 8.2 and 8.3.
Before we get started in earnest, let’s form an overview of the project that you’ll be working on.
The Robots Project
The Robots project contains two packages. The classes in o1.robots
constitute the
robot simulator’s internal model; o1.robots.gui
provides a user interface. The user
interface is ready for use as given and we won’t discuss it further here.
We’ll build the simulator on the same Grid
class that you used in Chapter 7.4.
The following table briefly describes each of the simulator’s main components. Below the table, you’ll find a diagram of the components’ relationships.
Package | Component | Description | Status |
---|---|---|---|
o1 |
class GridPos |
Represents pairs of coordinates. (Familiar from Chapters 6.2 and 7.4.) | ready |
o1 |
abstract class Grid |
Represents grids in general. (Familiar from Chapter 7.4.) | ready |
o1 |
sealed abstract class
CompassDir |
Represents the main compass directions. There are exactly four instances of this class, which stand for north, east, south, and west. (Familiar from Chapter 6.2.) | ready |
o1.robots |
class RobotBody |
Represents the robots’ physical form. Each instance
of RobotBody has properties such as location and facing.
A robot can be either intact or broken. |
partially implemented |
o1.robots |
abstract class
RobotBrain |
Represents the general properties of the robots’ “artificial intelligence”. | partially implemented |
o1.robots |
classes Spinbot ,
Nosebot , Staggerbot ,
Lovebot , and Psychobot |
Subclasses of RobotBrain . Each of these subclasses
represents a different sort of
robot behavior. |
Spinbot
partially
implemented;
others missing |
o1.robots |
trait Square |
Represents a single square of a robot world in general terms. | ready |
o1.robots |
class Floor |
Extends Square . Represents floor squares that the
robots move on. |
partially implemented |
o1.robots |
singleton object Wall |
Extends Square . Represents a wall. (A single object is
enough for this purpose, since all walls are identical.) |
partially implemented |
o1.robots |
class RobotWorld |
A subclass of Grid . Represents robot-inhabited grids
that are composed of Square objects. A RobotWorld
object also tracks which robot’s turn it is to act next. |
partially implemented |
Part 0 of 8: Answer Some Questions
Before you go on
Try to get a general sense of the Robots project by reading the description above and the Scaladocs. Browse the source code, too.
Part 1 of 8: Fundamental Repairs to RobotWorld
You’ve been given a whole bunch of code, much of which works in principle, but the program is not ready to run. Eclipse spews a stream of errors.
RobotWorld
has been only partially implemented. Fix it:
- The error messages indicate that
RobotWorld
doesn’t have the variableswidth
andheight
as expected. It should inherit these methods fromGrid
. Add anextends
clause that makesRobotWorld
a subclass ofGrid
.- You may wish to look at
GameBoard
in the Viinaharava game for inspiration. - Read the documentation carefully. Make sure you pass in the right numbers as constructor parameters to the superclass.
- Once you’re done with this step, try launching
the program via
o1.robots.gui.RobotApp
. You should see a robot world that’s completely dark. - Be sure to give
Grid
the type parameter it needs. (If you receive error messages that featureNothing
as the type of the grid’s squares, you probably overlooked this.)
- You may wish to look at
- Repair the
RobotWorld
methodinitialSquare
, which now fills the entire world with walls. The method is private and not detailed in the Scaladocs, but there’s a comment in the given code that explains what it should do: put walls on the edges and floors in the middle.- That is, you’ll need to check the coordinates
to determine whether you should create a
Floor
or use a reference to theWall
singleton.
- That is, you’ll need to check the coordinates
to determine whether you should create a
- Relaunch the application. You should be able to create empty robot worlds, but clicking the floor squares won’t let you add robots or walls.
Part 2 of 8: Adding Content to Robot Worlds
- Implement the
RobotWorld
methodaddWall
.- Hint: use
update
in classGrid
.
- Hint: use
- Run the program again and try right-clicking floors to add walls.
- Implement
addRobot
in the same class.- Note that
addRobot
needs to handle several interrelated subtasks. Make sure you attend to each of the things mentioned in the Scaladoc.
- Note that
- Try adding
Spinbot
s in the GUI. They should appear in the robot world, but they don’t do anything yet. You can break them and repair them, though.
Submission form
Use this form to submit your solution to Parts 1 and 2.
A+ presents the exercise submission form here.
The assignment continues in upcoming chapters.
Feedback
Please note that this section must be completed individually. Even if you worked on this chapter with a pair, each of you should submit the form separately.
Credits
Thousands of students have given feedback that has contributed to this ebook’s design. Thank you!
Weeks 1 to 13 of the ebook, including the assignments and weekly bulletins, have been written in Finnish and translated into English by Juha Sorva.
Weeks 14 to 20 are by Otto Seppälä. That part of the ebook isn’t available during the fall term, but we’ll publish it when it’s time.
The appendices (glossary, Scala reference, FAQ, etc.) are by Juha Sorva unless otherwise specified on the page.
The automatic assessment of the assignments has been programmed by Riku Autio, Jaakko Kantojärvi, Teemu Lehtinen, Timi Seppälä, Teemu Sirkiä, and Aleksi Vartiainen.
The illustrations at the top of each chapter, and the similar drawings elsewhere in the ebook, are the work of Christina Lassheikki.
The animations that detail the execution Scala programs have been designed by Juha Sorva and Teemu Sirkiä. Teemu Sirkiä and Riku Autio have done the technical implementation, relying on Teemu’s Jsvee and Kelmu toolkits.
The other diagrams and interactive presentations in the ebook are by Juha Sorva.
The O1Library software has been developed by Aleksi Lukkarinen and Juha Sorva. Several of its key components are built upon Aleksi’s SMCL library.
The pedagogy of using tools from O1Library (such as Pic
) for simple graphical programming
is inspired by the textbooks How to Design Programs by Flatt, Felleisen, Findler, and
Krishnamurthi and Picturing Programs by Stephen Bloch.
The course platform A+ has been created by Aalto’s LeTech research group and is largely developed by students. The current lead developer is Jaakko Kantojärvi; many other students of computer science and information networks are also active on the project.
For O1’s current teaching staff, please see Chapter 1.1.
Additional credits appear at the ends of some chapters.