Assignment 3
Assignment 3
Assignment 3
1
Input, Output, and Error
Your program should take input from stdin, and output to stdout. Errors should be output to stderr.
Errors should always start with “Error:” followed by a brief description. All your processes should
terminate gracefully (and quietly) once you see EOF at stdin. Your program should not generate any
extraneous output; for example, do not print out prompt strings such as “please enter input”
and things like that.
As the example above indicates, there are two kinds of inputs the user provides. One is via the
command-line arguments, like -s and -n switches. This is done only once, when your program is
started. The other input is the ’s’ command on stdin, which may be issued repeatedly, just as in
Assignment 2. For the ’s’ command, your program should output a shortest path.
We will not test your program for format errors in the input. That is, the command-line
arguments, whenever specified, will be formatted correctly, and the s input will also be formatted
correctly. Of course, we may omit command-line arguments (see below for what to do in such cases),
and specify vertex IDs to s that do not exist, or between whom a path does not exist. The latter
two cases should cause your program to report an error.
Marking
• Does not compile/make/crashes: automatic 0
• Your program runs, awaits input and does not crash on input: + 20
• Run in default mode: + 15
• Error check arguments: + 5
• Test functionality: + 20
• Test rgen: + 20
• Replace rgen: + 20
CMake
As discussed below under “Submission Instructions”, you should use a CMakeLists.txt file to build
your project. We will build your project using the following sequence:
cd PROJECT && mkdir build && cd build && cmake ../ && make install
where PROJECT is the top level directory of your submission. If your code is not compiled from
scratch (i.e., from the C++ sources), you get an automatic 0.
Note that we are using make install instead of make. The install target instructs make to
copy all of the binaries (both Python and C++) into directory ./run/bin. This ensures that all
the executable files (including the Python program) are in the same directory.
Submission Instructions
You should place all your files at the top of your gitlab repository. The repository should contain:
• All your C and Python source-code files.
IMPORTANT NOTE: the executable for your random generator must be named rgen. The
reason is that part of our testing will replace your generator with ours.
• A CMakeLists.txt, that builds all of the C++ executables: rgen, a2ece650, and a3ece650.
• A file user.yml that includes your name, WatIAM, and student number.
See README.md for any additional information.
You should place all your files at the top of your gitlab repository. The repository should contain:
• All your C++ and Python source-code files; you may use further subdirectories if you wish;
• A CMakeLists.txt, that builds all C++ executable files;
• A file README.md that includes your name, WatIAM, and student number.
2
• The hours you spent on finishing the assignment.
The submitted files should be at the top of the master branch of your repository.
File names
There are two file names that are important. One is your main executable. This must be named
a3ece650. Our marking script will simply try and run this after building your project. The other
executable file whose name is important is your random input generator. The executable for this
must be named rgen. The reason is that for some of our tests, we will replace your rgen with ours.
Things to be done
Python script
You should edit your Python script from Assignment 1 so that its output format for the specification
of the graph matches the input format for your C++ program from Assignment 2. Think of it as
though your Python script provides command-line input to the C++ program. The way to do
this is to simply map each vertex to an index in [0, n − 1] (where n is the number of vertices), and
rename your edges accordingly.
Also, the only output that your Python script should produce to stdout is in response to “g”,
for which it outputs the specification of the graph (i.e., V and E). Error output should go to stderr.
Cpp program from Assignment 2
You should edit it to print the graph that it has read before accepting an s command. This is
necessary so that you know what graph has been produced and what vertexes are available.
Random input generator
Your random input generator rgen should generate random inputs of street specifications for your
Python script. It takes four command-line arguments. All are optional.
• -s k — where k is an integer ≥ 2. The number of streets should be a random integer in [2, k].
If this option is not specified, you should use a default of k = 10; that is, the number of streets
should be a random integer in [2, 10].
• -n k — where k is an integer ≥ 1. The number of line-segments in each street should be a
random integer in [1, k]. Default: k = 5.
• -l k — where k is an integer ≥ 5. Your process should wait a random number w seconds,
where w is in [5, k] before generating the next (random) input. Default: k = 5.
• -c k — where k is an integer ≥ 1. Your process should generate (x, y) coordinates such that
every x and y value is in the range [−k, k]. For example, if k = 15, all of your coordinate values
should be integers between −15 and 15. Default: k = 20.
Your program should generate a specification of streets in the format that your Python script
expects (see Assignment 1). You can name the streets whatever you want. You should ensure
that your input does not have errors. For example, if you generate a line-segment that overlaps
with a line-segment (across all streets) generated earlier, you should regenerate that line-segment.
Similarly, you should not have any zero-length line segments.
Also, note that your random generator could go into an infinite loop looking for a valid specifi-
cation. You should disallow this from happening by limiting the number of tries. That is, if your
random generator fails to generate a valid specification for a continuous N number of attempts, it
should exit() with an error message reported on stderr, and the program ends, (i.e., all other pro-
cesses will be also terminated). A reasonable value to adopt for N could be 25. Whatever value N
you adopt, your error message should mention it. That is, your error message should be something
like, “Error: failed to generate valid input for 25 simultaneous attempts”.
3
Before a new specification to your Python script, your generator should issue “r” commands to
your Python script to remove all previous streets and replace them with the new specification of
streets.
After generating the input, the generator must issue the “g” command.
Thus, a typical interaction of the random generator is as follows:
3. issue a g command;
You must use /dev/urandom as the source of your random data. Also, see under “Submission
Instructions” how your executable for the random generator must be named.
Driver
Your driver program has the overall control. You have at least three programs that run concurrently:
(1) the random generator, (2) your Python script from Assignment 1, and, (3) your program from
Assignment 2 that takes as input a graph-specification and computes shortest paths. Your driver
program should fork() two processes and exec() two of those programs, and then exec() the
third (so it turns into a process that corresponds to the third program). It should set up all IPC
appropriately beforehand.
It should send normal output to stdout, error output to stderr, and take input from stdin. As
we mention above, the only input it takes are “s” commands, that ask for a shortest path between
vertices.
Gotcha warning: note that I say “you have at least three programs that run concurrently.” You
may need more than three that run concurrently. (Why?)
Sample code
The skeleton repository for the assignment contains some sample code. You should replace all
sample code with your own code. Including replacing the Python code with your solution from
Assignment 1, and C++ code from your solution to Assignment 2.
You might find the samples in the C++ repository for the course useful while working on this
assignment:
https://github.com/eceuwaterloo/ece650-cpp