17-654/17-754 Analysis of Software Artifacts Course Policies
Overview
The goal of this course is to communicate how analysis techniques can
be applied throughout the software lifecycle to increase the
effectiveness of software engineers. So that students can better
understand how to reason about programs and the benefits and
limitations of various analysis techniques, the course will broadly
cover analysis theory including program semantics, hoare logic,
dataflow analysis theory, temporal logic and model checking,
abstraction, and techniques for showing that abstractions are
sound. The course will cover analysis techniques that can be used
across the software lifecycle, including model checking of designs,
code reviews, code verification and bug-finding, and analysis
techniques for effective software evolution, maintenance, and
reengineering. Topics include not just analysis for correctness,
but also analysis techniques for quality attributes such as security,
reliability, performance (including real-time), memory usage, and
evolvability. Students will become familiar with several analysis
tools developed in academia and industry, both through readings in the
research literature and practical experience trying out one or more
tools.
After completing this course, students will:
- know what kinds of analyses are available and how to use them
- understand their scope and power, when they can be applied and
what conclusions can be drawn from their results
- have a grasp of fundamental notions sufficient to evaluate new
kinds of analysis when they are developed
- have some experience selecting and writing analyses for a real
piece of software, applying them and interpreting the results
Prerequisites:
- Basis programming experience in a high-level language
- An undergraduate-equivalent background in discrete mathematics,
as provided by 21-228, 15-251, or Models (17-6XX/17-7XX)
This course fulfills the Analysis STAR requirement for the Software
Engineering Ph.D. program.
Evaluation
Evaluation will be based on the following approximate percentages:
- 60% assignments
- 15% final project
- 15% final exam
- 10% participation and readings
The assignments will include:
- Questions covering the theory of various analysis technologies,
as well as their benefits and limitations in concrete engineering
settings (the exams will cover similar material in an evaluative
setting)
- Applying commercial and research analysis tools to software
artifacts and reporting on the results (in writing and with an in-class
presentation)
- Writing simple analyses and applying them to verify engineering
properties of code
There will also be a more in-depth analysis project, to be arranged
with the instructor. The project will include at least a
written report (whose length will depend on the specific project and
whether it has an additional implementation component) and a
presentation in class. Example projects might include:
- A literature survey in a sub-area of analysis, describing what is
the current state of the art and what are open research questions in
the area.
- A comparative evaluation of one or more analysis techniques or
tools, based on experience applying the tools to software artifacts.
- The development of an interesting new analysis technique, or
application
of an existing technique to a new problem domain.
Time Management
This is a 12-unit course, and it is my intention to manage it so that
you spend close to 12 hours a week on the course, on average. In
general, 3 hours/week will be spent in class and 9 hours on on readings
and assignments. To give me feedback on how much time the course
is taking, I ask that you keep track of the number of hours spent on
each assignment and report the time when you turn in the assignment
(many of the MSE students are doing this in any case, so it should be
little additional work).
Late Work Policy
Each student has 5 late days for the semester which can be used in any
assignment. When turning in your work, just let the instructor or
TA know how many late days you are using. Work turned in late
after the late days are used up will only be accepted under
extraordinary circumstances.
Collaboration Policy
You may discuss any of the readings or assignments with your
classmates. You may also help each other with technical problems,
for example, with getting course software to run, answering questions
about how course software works, debugging an assignment, or getting
notation right (if any of this means looking at another student's
solution, the expectation is that you will already have done that part
of the assignment--but it is preferable to discuss the problems in the
abstract rather than in the context of a specific solution).
However, your assignment writeup or coding must be your own work.
Thus, you may not copy any part of a solution to a problem that was
written by another student, or was developed together with another
student. Nor may you look at another student's solution as you
develop your own. If you have worked together on something, you
must throw away your notes and re-develop the solution yourself, so you
are confident it is your own work. Any violation of this policy
is cheating. If you have any question about how this policy
applies in a particular situation, ask the instructor for clarification.
Some assignments are specifically noted as group projects. For
these, interpret "you" in the preceeding paragraphs to mean "you and
your partner(s)."
If your completed assignment contains any statement that was not
written by you, you must put it in quotes and cite the source. If you
are paraphrasing an idea you read elsewhere, you must acknowledge the
source. Using exisitng material without proper citation is
plagiarism, a form of cheating.
The minimum penalty for cheating (including plagiarism) will be a zero
grade for the whole assignment. Cheating incidents will also be
reported through University channels, with possible additional
disciplinary action.