LUNDS TEKNISKA HGSKOLA Datavetenskap
Realtidsprogrammering, vn 4/lab 2 D3, lp1 2000/01
Exercise session 4 and Lab 2: Washing machine
The programming task
Your task is to implement the control software for a washing machine. The machine is equipped with water level and temperature sensors. In addition, four buttons allow the user to select a washing program (1, 2, 3) or stop the machine (0). Output signals from your software will control the following: A valve for letting water into the machine. A drain pump for draining the machine. A heater for heating the water. A motor for the rotation of the barrel. The motor has the modes left spin, right spin, fast spin (centrifuge), and stop.
Basic requirements The machine shall have three washing programs with the following behavior: 1. Color wash: Lock the hatch, let water into the machine, heat to 60oC, keep the temperature for 30 minutes, drain, rinse 5 times 2 minutes in cold water, centrifuge and unlock the hatch. 2. White wash: Like program 1, but with a 15 minute pre-wash in 40oC. The main wash should be performed in 90oC. 3. Draining: Turn off heating and rotation. After pumping out the water (if any), unlock the hatch. Note: the user should select this program as soon as possible after 0 (stop). 0. Stop: All motors, as well as any lling/draining of water, should be turned off immediately. The main difference between 3 and 0 is that 0 can used as an emergency stop. Program 3 can be used to end a washing after interrupting it (with 0) or after a power failure. The program selector should require the user to always stop the machine (i.e., press 0) before switching from one program to another. Additional requirements: The temperature must not exceed the ones stated above (60, 40, and 90oC) but may sporadically drop down to 2oC below. An electromechanical relay controls the power to the heater. To avoid wearing out the relay, it should not be switched on/off too often. While washing, the barrel should alternate between left and right rotation. The direction should be changed once every minute. Requirements for CMLA certication To market the washing machine in the EU, the control software must be reviewed and certied by a special committee, CMLA (Comit de Machines Laver Automatiques), in Brussels. The special requirements from CMLA are listed below. Since the review is a costly and time-
consuming process, it is very important that the software is written in a way that allows the CMLA requirements to be veried easily. In other words, it should be easy to convince oneself that the requirements are fullled by simply inspecting the code. CMLA states the following requirements, motivated by environmental and safety reasons, for a washing machine to be certied: 1. The drain pump must not be running while the input valve is open. 2. The machine must not be heated while it is free of water. 3. There must not be any water in the machine when the hatch is unlocked. 4. Centrifuging must not be performed when there is any water in the machine.
API Application Programmers Interface
The hardware for the new washing machine is developed in parallel with the control software. To make it possible to test the control software early (and save some water), a software simulation of a washing machine has been developed. The GUI is shown at the end of this document. Washing machine hardware access The abstract class AbstractWashingMachine describes the properties of a washing machine and provides operations for manipulating the (possibly simulated) hardware. Your control software will only communicate with the AbstractWashingMachine class, not the concrete subclasses implementing the actual hardware interface and the simulation. WashingView The simulation is based on the following data: Volume: Power: Water input ow: Water output ow: Rotation speed: 20 l (lled up to 10 l) 4.2 kW 0.1 l/s 0.2 l/s 0.25 revolutions/s (slow), 800 revolutions/min (fast)
A complete wash typically takes 45min - 1h to complete. To facilitate testing the simulation has a speed parameter which can be used to speed up the simulation. Speed=1 corresponds to actual time, and e.g. speed=10 makes the simulation go 10 times as fast. Although the prewritten simulation software takes the speed parameter into account, you still have to use it yourself in some parts of your code. For instance, the washing times (15, 30, and 45 minutes) must be scaled in the control software to get a consistent simulation.
Your task
Your task is to develop the control software for a washing machine as described. Use events for thread synchronization and communication. The exercise session During exercise session 5, the general design of the control software is discussed, including threads and communication mechanisms. A complete design should be prepared and implemented before the lab session.
Which concurrent activities (i.e., threads) do you need? Think about which inputs the system should handle, and how it should handle them. Is there any thread that is more time-critical than the rest (and should be given a higher priority)? Is it appropriate to introduce more threads to accomplish a clearer and more understandable design? Will the CMLA requirements be easy to verify (by quickly inspecting the code) in your implementation? Which threads need to communicate? Draw a simple diagram to show your design. What information (which classes) should be communicated? Pre-dened classes Apart from the AbstractWashingMachine class mentioned above, you will (directly or indirectly) use six more classes. These classes are: se.lth.cs.realtime.event.RTEvent: a class which you should use as a superclass for your own event classes. se.lth.cs.realtime.event.RTEventBuffer: a bounded queue for RTEvents. Every RTThread has a protected reference, named mailbox, to such a queue. This queue holds all events sent to the thread using its putEvent method. se.lth.cs.realtime.RTThread: a special thread class used in the se.lth.cs.realtime package. For the purposes of this laboratory the RTThread can be considered equivalent to the standard Thread class. You use it in the same way you would use the Thread class, i.e. by subclassing it and writing a run() method. se.lth.cs.realtime.PeriodicThread: a special kind of thread (subclass of RTThread) that is executed periodically. As for ordinary threads, you create periodic threads by subclassing PeriodicThread. The periodic task is written in the perform() method in your subclass (as opposed to run() in an ordinary thread). The perform() method should be declared as follows:
protected void perform() { ... }
Note that since perform() is called periodically (not only once, like run()), it should not contain any innite loop as run() sometimes does. In addition to these classes, you will come across the following interface: done.ButtonListener: classes that implement this interface can be used to take care of pressed buttons (such as the 0, 1, 2, and 3 buttons of the machine). Your WashingController class should implement this interface.
Your implementation Your classes should be put in a package named todo. You are expected to write a class WashingController which should be used as a wrapper for the other classes you develop. The (previously written) main method will create one object of that class. The WashingController class has two responsibilities: To provide a constructor
WashingController(AbstractWashingMachine theMachine, double theSpeed)
with two parameters. The rst parameter is the (possibly simulated) washing machine to control; the second is the speed parameter described previously. This constructor is a good place to create objects and start threads.
To implement the ButtonListener interface, that is, provide a method
public void processButton(int theButton)
which is called by the washing machine (hardware driver or simulation) whenever the user presses one of the four program buttons on the machine. The parameter has a value in the interval 0..3 to indicate which button was pressed. To start the washing machine simulation with your control software, rst make sure your current directory is the same as where the todo directory is located (not in the todo directory). Then type java done.Wash -speed 50 to get going. (The number after the -speed option is the simulation speed. 50 is a good value.) Certication Convince your instructor that your implementation works and the CMLA requirements are fullled. Motivate why the temperature cannot exceed the desired value. Motivate why the temperature control relay does not switch on/off too often. GUI