This project was given to the students of the 2004 class. At the end of that project, the students felt that it still had room for further development of the ideas. So we're going to re-use the same project, with the bonus that the 2006 class will get to see the 2004 software, discussion and reports and submitted code, and be able to build on the previous work. Of course, you're welcome to start from scratch if you think you have a new way of approaching the problem. (An advantage of starting with a previous problem is that it is easier to learn the mechanics of working with the provided programming interface.)
Here's the 2004 description:
The recently completed Olympic Games have a cycling event called the road race. In that event, riders ride for several hours (3 hours or more for the women, 5 or more for the men) over the local road system.
The most critical physical constraint in cycling is that a rider who rides without anybody in front of him/her absorbs all of the wind resistance. A rider riding immediately behind another rider uses 30% less energy than a rider riding in front.
A simple strategy is to ride in line in a group, and to take turns leading the group. However, this can be an unstable strategy, because there is an short-term incentive for each rider to do less than their fair share in front. If the group cooperation breaks down, then each rider backs off to allow other riders to lead, and eventually a trailing group of riders can catch up. Thus there is a longer-term incentive for the group as a whole to cooperate.
While the race is theoretically an individual race, one can only succeed by riding in the context of a team. In the Olympics, teams are based on country, and each country optimizes its strategy for the success of one of its riders. The aim is to get the team's best rider into first place by having the other riders play supporting roles.
In real life, there are some relatively subtle strategies based on having riders with different abilities. For example, it is considered a bad idea to form a breakaway group with a rider who is a much better sprinter, because that rider will win out at the end of the race. Our project will simplify the problem by assuming that all riders are physically homogeneous. The race will therefore be won or lost on strategy alone.
Like the Olympics, we will focus on the first three places. A team scores 5 points for a gold medal, 3 points for silver, and 1 point for bronze. The ranks of other riders, including whether a rider finishes the race or not, do not matter.
A rider has a certain quantity of energy, and all riders start with the same energy. Energy is used at differing rates during the race, as described below.
The course is divided up into lanes. There are many lanes, and riders can switch to adjacent lanes whenever they like (if there's space in the lane). Lanes abstract the concept of being behind (and therefore in the slipstream of) another rider. If rider A is in the same lane as B, and sufficiently close to the rear of B, then A's energy consumption will be reduced.
A bicycle is assumed to be 2 meters long, so that riders in the same lane must be at least 2 meters apart, measured from the front of each rider's bicycle. Riders cannot pass other riders in the same lane. To pass, a rider must move left or right to an adjacent lane, and then try to pass. If the adjacent lanes are occupied at a rider's position, then the rider cannot change lanes. If two riders simultaneously try to switch to the same lane, then the rider who is ahead has right of way. (In the unlikely event that two riders are at exactly the same position, the rider on the left, i.e., the one in the lane with the smaller number, has priority.) Note that the far-left and far-right lanes allow switching in only one direction. Two riders cannot exchange lanes if their positions overlap.
We will assume for this project that the course is flat and straight.
Energy consumption per second is equal to units where is the speed of the rider. However, if there is a rider in the same lane at a distance in front, then energy consumption is reduced by a factor , i.e., the energy required is multiplied by . for , and otherwise. (Recall that must be at least 2.) In other words, there is a 30% saving in energy for a rider immediately behind another rider, and that benefit decreases linearly to zero as approaches .
Every second, riders may adjust their status by:
The energy used during the previous second is calculated by the system (an integral of with respect to time, over 1 second). In the event that the simulation takes too long, we might increase the simulation granularity from one second to ten seconds.
Even with an infinite energy budget, no rider may exceed 25 m/sec.
If a rider's proposed acceleration would cause a collision with the rider in front, then the system will automatically reduce the speed of the following rider to avoid the collision. Thus, riders in front have the ability to set the pace for their lane, and can deliberately slow down the pace. By swithing lanes, though, riders can pass a slow leader. (Question: Can a leader keep a follower behind by constantly changing lanes in front of them?)
Riders start with a fixed energy budget. Energy is subtracted from the budget each second. If a rider's energy drops to zero, then the rider drops out of the race. To simplify the dropping out process, the rider disappears immediately from the field, rather than slowing down and falling behind the other riders.
Each rider starts in a randomly assigned lane. The number of lanes will always be greater than the number of riders; riders will start alone in their assigned lane, without riders in front of them.
Here are the parameters that will be used by the simulator:
Parameter | Typical Value | Description |
L | 50 | number of lanes |
D | 180,000 | length of the race in meters |
T | 8 | number of teams in the race |
R | 4 | number of riders per team |
E | 5,000,000 | initial energy per rider |
will probably be chosen to match the number of groups in the class.
With these parameters, a rider could ride alone at 9m/sec, using 243 units of energy per second. It would take 20,000 seconds to finish the race at this speed, which means a total energy consumption of 4,860,000, which is within the energy budget.
Riders are in touch with the team coaches by wireless phones, and follow team orders. Team coaches have access to complete information about the state of the race, including the positions, speeds, and remaining energy budgets of all riders. Each second, the team coach provides instructions for the rider, and those instructions (together with the instructions of the other coaches) are simulated by the project simulator.
Some initial thins to think about:
We will run multiple tournaments, and calculate the average score per team over all tournaments. Players may learn the behavior of competing teams over time, and adjust their strategy accordingly. The extent to which groups are permitted to form meta-alliances will be decided during class discussion. For example, are the following legitimate?