This is a written assignment similar to Assignment 2. Once gain you will diagram call frames. But this time we are more concerned with folders: both object and class folders. The purpose of this assignment is to help you understand the issues with name resolution that we discussed in class.
This assignment is going to overlap Assignment 6. That means we will be posting Assignment 6 before this assignment is due. That is because Assignment 6 is due just before the second prelim, and we want to make sure that you have ample time to both study and work on the assignments. As this is a written assignment, and you already have a lot of experience with call frames, this should not be a problem.
Authors: W. White, L. Lee, and S. Marschner
Learning Objectives
This assignment is design to help you understand the following concepts.
- How to draw object folders to represent the contents of an instance.
- How to draw class folders to represent the shared content of all instances.
- How object and class folders are used to resolve naming issues.
- How method calls are similar to function calls.
Table of Contents
- Academic Integrity and Collaboration
- Diagramming Conventions
- Assignment Instructions
- Finishing Touches
Academic Integrity and Collaboration
This assignment is a modified version of an assignment given in a previous semester. Please do this assignment without consulting (or seeking) previous solutions. Consulting any prior solution is a violation of CS1110’s academic integrity policy.
We also ask that you do not enable violations of academic policy. Do not post your solutions to Pastebin, GitHub, or any other publicly accessible site.
Collaboration Policy
You may do this assignment with one other person. This does not have to be the same person that you partnered with in the previous assignment. You are free to change partners after every assignment.
When you upload your pdf to Gradescope, you will be given the option to add a person to the submission. You may find these instructions helpful. You also must work together. It is against the rules for one person to to fill out this assignment and just have the other person put their name at it. Other than your partner, you may not collaborate with anyone else on this assignment.
The Python Tutor
By now, everyone is very familiar with the Python Tutor. Once again, using the Tutor makes parts of (but not all of) this assignment easy. We are perfectly okay with this. It is a good way to help you understand the formalism if you are particularly lost.
If you used the Python Tutor to help you with part of the problem, please cite this (for each part that you used it) in your submission. We will not take off any points if you use the Tutor and cite it. We only want a citation to be consistent with our academic integrity policy.
Assignment Help
Even though this is just a written assignment, some of you may still have some difficulty with it. You might not completely understand how function calls work or the purpose of folders. If you are lost, please see someone immediately. This can be the course instructor, a TA, or a consultant. Do not wait until the last minute, as the course staff can get overwhelmed just before an assignment deadline. See the office hours page for more information.
Diagramming Conventions
You are already familiar with most of diagramming conventions from Assignment 2. Our new conventions build on top of these. All of our examples below use the following class definition.
1
2
3
4
5
6
7
8
class Example(object):
CONST=3
def __init__(self):
pass
def foo(self):
return 42
The line numbers to the left are used in the method call frames, just as in Assignment 2.
Diagramming Class Folders
When you define a class, Python creates a special folder called a class folder that stores the information about that class. Technically, Python also creates a global variable with the same name as the class and puts the name of that folder in the global variable; that is what you see when you put the class above in the Python Tutor.
To simplify things, we do not want you to show the variable in global space (just like we never ask you to show the variable for a function name in global space). We just want you create a folder in the heap, and put the name of the class in the tab. We also want you to put the tab on the right so that we can tell this is a class folder. This is illustrated below.
The class folder contains all the methods and any class attributes. In a class definition,
any assignment statement outside of a method definition creates a class attribute. In
the example above, CONST
is a class attribute.
Technically, the methods are also variables themselves. This is what you would see if
you used the Python visualizer. However, the contents of this variable are really
complicated, and the Python visualizer just writes the method header (the name plus
all of its parameters) as its value. Therefore, that is what we want you to
write for the methods in a class: the method header (without the def
).
The example above works when the class is a base class (e.g. a subclass of class
object
). Suppose we have a class that is a subclass of a user-defined class,
like the example Demo
below.
1
2
class Demo(Example):
pass
We want to indicate this relationship in our class folders. To do this, we put the name of the parent class in parentheses, as shown below. Note that this class has no methods or class attributes in it, because there are none in the class definition.
Diagramming Object Folders
A object is instance of a class. While there is only one class Example
,
there may be more than one Example object. Each time you call the constructor,
you create a new object. For example, suppose we execute the following statements:
The constructor for Example
creates an empty folder (why?), while the second
assignment statement adds an attribute x
to the folder. The end result is
as follows:
The instance folder only contains attributes added to the instance. It does not contain class attributes, and (for this course) it never contains methods.
Diagramming Method Calls
A method class works almost exactly like a function call. You create the call frame, and plug the arguments into the parameters. You then execute each line in the method, changing the call frame as necessary. Finally, you erase the frame.
The only real difference is the function name that goes in the upper left box. We want both the name of the class and the method name in this box. For example. for the method call
the initial diagram for the call frame is as follows
Note the name is not foo
in the top left folder, but Example.foo<
.
That tells us to use the version of foo
that is stored in the class folder
Example
.
Diagramming Constructor Calls
A constructor is just a function, so Python should create a call frame when it is called.
However, this function is built-in, so we do not really know what it looks like. You will
notice that the Python visualizer does not create a call frame for the constructor either.
However, it does create a call frame for the initializer __init__
, which the
constructor uses as a helper.
We are going to do it the way that the Python visualizer does it. Remember the 4 steps of a constructor call:
- It creates a new empty folder of that class.
- It puts the folder into the heap</li>
- It executes the method
__init__
(creating a call frame)</li> - It returns the folder name
In our diagram, we combine steps 1 and 2 (because otherwise we do not know where to put
the folder). We also combine step 4 with the erasing step of __init__
even
though __init__
has no return variable. For example, if we executed the constructor
The resulting diagram would be as follows.
The first diagram is the folder creation step, before the method init is called. The next two diagrams are for the call frame for init. The first picture is at the start of the method, and the second picture is the execution of the one an only line of the method (which does nothing). In the final diagram, we erase the frame and assign the value to our variable.
Assignment Instructions
This entire assignment will involve the following two mysterious (and undocumented) classes.
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
class A(object):
x=4
y=5
def __init__(self,x,y):
self.x = y
self.z = x
def f(self):
return self.y+self.y
def g(self):
return self.x+self.z
class B(A):
x=2
z=3
def __init__(self,x,y):
super().__init__(x,x)
self.x = y
def f(self):
a = self.g()
return self.y+a
Once again, you should use the line numbers provided when drawing the method call frames. We have kept all of these methods short to cut down on the amount that you have to draw.
Part A: Diagram the two Class Folders
The instructions are in the title for this section. We just want you to draw two
class folders. You draw one for the class A
and another for the class B
.
Do not draw global space (even though there are global variables A
and
B
that refer to these class folders). There is also no call frame to draw.
You can complete the class folder for A before the Tuesday, November 5 lecture. The folder for class B requires a minor change from the subclasses lecture, but you can figure it out from the instructions above.
Part B: Diagram the Execution of p = A(1,5)
Draw the execution of the statement
This is a constructor call, so it will involve the creation of a call frame for
__init__
. As usual, you will need a diagram for when the frame for __init__
created, and another when it is erased. In between, you will diagram the lone
line of code that is executed.
However, as described above, you do not draw the
call frame right away. You need a step creating the folder first. In particular,
you will need to draw how global space and the heap changes with the call frame,
just like you did on the prelim. You do not need to add anything to global space
beyond what is required for the statement p = A(1,5)
.
In particular, you do not need a global variable for class A
.
You can complete this part before the Tuesday, November 5 lecture.
Part C: Diagram the Execution of q = B(7,3)
This problem is exactly like Part B.
We need the evolution of global space, the heap, and the call frame for __init__
.
The difference this time is that there is a call stack created with more than one frame
(just like on the first prelim). You should draw that properly.
You do not need to include p
(from Part B) in your diagram of global
space.
Part D: Diagram the Execution of r = q.f()
In this problem, q
is the variable from Part C.
Diagram the evolution of the call frame for method f
. This is a normal method call
(not a constructor), as described above. If this method
calls another method as a helper, you should draw the complete call stack, just like you
did in the previous problem.
Your diagrams should include the contents of global space at each step. You do not need
to draw the heap, since method f
will not change the contents of any folder.
Finishing Touches
When you finish the assignment, put your name and netid at the top of every page. Otherwise, we might lose track of the assignment, and we cannot give you credit for your work. If you are working with a partner, then the partner’s name and netid must be on the assignment as well.
Creating a PDF for Submission
We want you to submit your work as a PDF. If you created your assignment on a computer, this should be relatively easy. Otherwise, you will need to scan your paper as a PDF. There are scanners in Olin and Uris Library to help you with this.
Your solution should be a single PDF file. You cannot submit multiple PDF files. If your scanner makes more than one file, you must combine them together. On Windows, the program PDFtk can merge multiple PDF files into one file. In OS X, the built-in application Preview can be used to merge PDF files.
Uploading to Gradescope
Written, PDF-based assignments will be handled this semester through Gradescope. This will allow us to mark up your PDFs with feedback and allow you to see them right away. It is not a great service and it has many issues, but has the advantage that you can verify your submission to make sure it is readable, complete, and that all questions are answered. You cannot do that in CMS.
If you are enrolled in the course, an account has been created for you on Gradescope with your Cornell NetID email address. You should have received an email from Gradescope the day after Assignment 1 was due. Check your spam folder if you cannot find it. If you still cannot find it, you can perform a password reset using your Cornell NetID email address.
You must upload your submission to Gradescope by Thursday, November 7. Remember to add your partner when you submit. We do accept late submissions (up to Sunday) for a penalty of 10% per day. This is roughly a letter grade for each day late. Remember, once you upload, you should view your submission to make sure it is readable.
Completing the Survey
Once again, this assignment comes with a survey on CMS. This survey asks how long you spent on the assignment, your impression of the difficulty, and what could be done to improve it.
Please try to complete the survey within a day of turning in this assignment. Remember that participation in surveys compromise 1% of your final grade. We also ask that you be honest in your answers.