VG101讲解、辅导Matlab程序、解析Matlab编程、讲解Matlab设计、Matlab辅导

- 首页 >> Matlab编程

VG101 — Introduction to

Computer and Programming

Project 1

Manuel — UM-JI (Fall 2018)

Include simple comments in the code

If applicable, split the code over several functions

Extensively test your code and impove it

Write a single README file per assignment

Zip all the files and upload the archive on Canvas

1 Project setup

At a cross road cars are either moving if the light is green or waiting if it is red. A road is composed of

two lanes, for cars going in opposite directions while the light is located on the right hand side of the

cars, before the cross. Moving cars are all going at a same constant speed of one unit every second.

A snapshot of the scenario at a time t is shown on Figure 1. On the picture three cars are going from

top to bottom but are waiting as the traffic light is red. In the meantime five cars going from right to

left are crossing, while two other cars are coming from the opposite direction. The two last cars can be

seen coming from the bottom but have not yet arrived at the cross road.

Figure 1: Traffic at a cross road.

Requirement for the above scenario:

The user inputs n, the total number of cars,

w the width of the road, and p the probability

that a cars does not stop at the red

light;

The number of cars on each line is randomly

decided with respect to n;

The color cycle of a traffic light is green for

g s, orange for o s, and red for r s; The user

sets the value of the variables g, o, and r;

Lights in the diagonal of the cross road have

a same color;

Each time a light changes from green to

orange the cars before the light stop and

the ones which have already passed it finish

crossing; e.g. on Fig. 1 if the green light becomes

orange then the two cars in the middle

of the cross should finish crossing the road;

Cars should appear at the beginning of the road with respect to where they come from; e.g. a car

coming from the right should start from the right most edge of the figure;

Every second all the non-waiting cars move by one unit;

The goal is to animate the displacement of the cars with respect to the traffic lights. The choice of the

user will impact the risk for a car crash to happen. The animation stops as soon a crash occurs and the

player loses. If all the cars have gone through without any problem the player wins.

1

2 Tasks

Ex. 1 — Cross road traffic game

1. Write a simple function that initialises all the parameters, i.e. prompts the user for the number of

cars, the time for each light color, randomly generates how many cars go in each direction, etc..

2. Write a function that draws the cross road.

3. Write a clear and precise algorithm describing the motion of the cars as well as the change of color

of the traffic lights. Justify your choices. The algorithm should describe the whole animation of

the cross road.

4. Write several functions to plot the cars and animates the whole scenario of the game.

Each of the following questions is optional and will bring a bonus on the project grade if properly solved.

5. Design more realistic cars of various sizes.

6. Allow the cars to randomly turn left or right.

7. Allow cars to adjust their speed within a range specified by the user. They can in turn use this

information to prevent a crash.

8. Allow the player to choose a difficulty level and automatically adjust all the parameters accordingly,

e.g. number of cars, width of the road, right and left turns allowed, etc..

9. Add more lanes to the road.

Note: other adjustments are welcome and encouraged, however first discuss them with the teaching

team to check their validity and suitability for the project.

Ex. 2 — Registration plates

Each car features a registration plate composed one letter followed by a mix of five letters and digits,

e.g. B 34HB0. We want to generate a random plate for each of the car and return the plates of all the

cars which do not stop at the cross road.

1. Random permutations.

a) Write a recursive algorithm that takes as input a set of elements and an integer l, and returns

all their permutations of length l.

b) Adjust the previous algorithm to return a random subset of all the permutations containing

n elements.

Hint: generating all the permutations and selecting n of them afterwards in not a good idea.

2. Implement the generation of the registration plates in MATLAB, and assign a unique plate to

each car.

3. At the end of the game display the plate of all the cars that did not stop at the traffic light.

3 Milestones

In order to smoothen the progress and provide hints on how to get organised when working on the project

we defined three milestones. For each milestone students must submit their current code with all the

usual relevant files attached as well as with a short Changelog file that describes the progress done on

the project. Expected implementation for each milestone:

1. Crossroad and traffic light: October 2nd;

2

2. Car related functions (e.g. input, direction, drawing, output, plate, etc.): October 7th;

3. Whole animation: October 14th;

4 FAQ

This section lists all the Frequently Asked Questions (FAQ).

1. I do not understand a question. What should I do?

Use a monolingual dictionary to ensure you fully understand all the words appearing in the question.

Then discuss with other students to know how they understand it. Only discuss the question,

not its solution. If several opinions appear to be valid determine which ones is the best and most

reasonable. Document your choices in the README file. Alternatively contact the teaching team

through project 1 discussion on Piazza. To ensure everybody benefits from the question and its

answer no question will be answered if not asked on the project discussion;

2. What is w the width of the road?

The width of the road is how large the road is. It can be expressed in pixels or in term of time unit,

e.g. a width of 4 time units means that a car needs 4 time units to cross the cross road. Ensure

the user knows what unit is used when he is prompted for w.

3. The optional question requirements do not match the original scenario. What should I do?

The optional requirement overwrites the original one. For instance in the original scenario the speed

is uniform while in ex. 1 question 7 a car can change its speed. In that case the speed can be freely

adjusted.

4. Can I skip base questions and do optional ones instead?

No, a submission that does not implement the basic questions will not receive any bonus.

5. Can I make use of the Automated Driving System Toolbox?

The project must be completed with the help of any “advanced toolbox”. Completing two versions,

with and without, can bring bonus.

6. I have not read the ci.pdf file, can it impact my grade?

Yes, much information on the code quality appears in this file. No applying some of the rules can

bring large deductions on the project grade.

7. I cannot meet a milestone, how bad is it?

Deductions will be applied if functions from previous milestones are not fully working in the final

submission. Besides, no answer will be provided to questions on a previous milestone.


站长地图