python3 draw.pyo < draw.test
draw.py
and any other modules as needed.This is an individual homework. While you may discuss the ideas and algorithms of this homework with others, at no time should you read, possess, or submit the solution source code of any other person (including people outside this course), or allow anyone else to read or possess your source code. We will detect plagiarism using automated tools and will prosecute all violations to the fullest extent of the university regulations, including failing this course, academic probation, and expulsion from the university.
Create a simple drawing program.
A picture is worth a thousand words. In this assignment, transform those words back into a picture. You'll translate a drawing description into a PostScript file that will produce the specified picture. Your program should read input from stdin and output the PostScript file to stdout.
A drawing consists of zero or more picture elements, with each element modified by zero or more transformations. The drawing may also have zero or more parameter settings before any picture element. All numbers should be handled in floating-point. The coordinate (0,0) is the origin and is the lower left corner of the drawing. X-coordinate values increase to the right and y-coordinate values increase to the top.
Create picture elements using the commands below.
(line X0 Y0 X1 Y1)
(rect X Y W H)
Create transformations using the commands below.
(translate X Y)
(rotate X)
Create drawing parameters using the commands below.
(color R G B)
(linewidth W)
Zero or more whitespaces are allowed between a parenthesis and the start or end of a command, and between commands. At least one character of whitespace is required to separate arguments within a command.
For example, the following would draw a thick blue square, rotated 45 degrees.
We will test your program with only valid drawing input. In other words, your program need not handle input errors.
The output of your program will be a PostScript document. You can view a PostScript file with any PostScript viewer. A popular one is gv available on Linux. A PostScript file has the following form:
%!PS-Adobe-3.1
commands
showpage
The commands of the PostScript language are in postfix notation. The actual PostScript language is free form, meaning operands and operators can be separated by arbitrary whitespace. Your output, however, must mimic the reference program to make your program easier to debug and grade. Each command will start on a newline with operands separated by a single space.
The origin of a PostScript starts at (0,0) in the lower left corner,
with x-coordinates increasing to the right and y-coordinates
increasing to the top. To draw something, one builds a path, and then
stroke
s it. The PostScript interpreter maintains a
graphics state, which for our purposes consists of
You can use the following subset of the PostScript language to construct your PostScript file. In this subset, all operands are decimal numbers (e.g. 0.1, 2.3, 45).
X Y moveto
X Y lineto
stroke
W setlinewidth
R G B setrgbcolor
To tolerate small errors in floating point computation, the gradebot uses cmpfloat.py (SHA-1: 08ed50ecf4b0356527da25e967b06483876f7f75) to compare the output of your program to that of the reference program. When they are equal, cmpfloat.py outputs nothing.
(
, )
, line
, translate
, color
, etc.We provide an incentive against procrastination.
Your program must not exit with a non-zero status. This means that if your program calls exit()
, the argument must be zero.