me |
Research | Publications |
Teaching | Students | CV | Software | Funding | Activities |
Practical development tools include
Lectures |
Reading, Assignments, Tutorials |
|
Week 1 3/30, 4/1 |
Version Control System SVN, Git, Diff Lecture 1--Overview Lecture 1--Collaboration Scripting Unix Commands and Shell Scripting Lecture 2-Unix and Scripting Lecture 2-Shell Script.zip |
Subversion
Tutorial Git Tutorial Unix and Scripting Tutorial Lab: Part A Requirements |
Week 2 4/6, 4/8 |
Design Notation Use Case and State chart in UML Class Diagram, Sequence Diagram Lecture 3-UML Design Principles: Information Hiding Lecture 4-Information Hiding |
Overview
of UML UML Tutorial Article: On the Criteria to be used in decomposing systems into modules Lab: Discussion on Requirements |
Week 3 4/13, 4/15 |
Design Patterns Strategy, Observer, Mediator Abstract Factory, Factory Method Lecture 5-Design Patterns Part A Lecture 6-Design Patterns Part B |
Head First Chapter 1. Overview and Strategy Head First Chapter 2. Observer Head First Chapter 4. Factory Design Patterns: Strategy, Mediator, Observer, FactoryMethod Lab: Part B Requirements (Part A is Due) |
Week 4 4/20, 4/22 |
Design Patterns Singleton, Command, Adaptor Template Method, State, Flyweight Lecture 7-Design Patterns Part C Lecture 8-Design Patterns Part D Design Pattern Skeleton Code Snippets |
Head First Chapter 5. Singleton Head First Chapter 6. Command Head First Chapter 7. Adapter and Facade Head First Chapter 8. Template Method Head First Chapter 10. State Design Patterns: Singleton, Adapter, Flyweight Code: Java Code examples of Head First Design Patterns Lab: Discussion on Design Patterns |
Week 5 4/27 4/29 |
Build Management Lecture 9-Build Management Midterm (4/29 in Class) Assignment 1 is due on Wednesday 11:59 PM. |
Lab: Part C Requirements |
Week 6 5/4 5/6 |
Testing Statement, Branch, and Path Coverage Testing Bounded Iteration, Infeasible Paths, Test Generation, and Symbolic Execution Lecture 10-Testing Part 1 Lecture 11-Testing Part 2 Regression Test Selection Testing Activity Notes and Solutions |
Article:
Symbolic Execution and Program Testing JUnit Tutorial Lab: Part B is Due. |
Week 7 5/11 5/13 |
Hoare Logic Weakest Precondition and Loop Invariant Lecture 12-Hoare Logic Part 1 Lecture 13-Hoare Logic Part 2 Assignment 2 is due on Wednesday 11:59 PM. Code Inspection Activity Notes and Solutions |
Weakest
Precondition-HandwrittenNote1.pdf Weakest Precondition-HandwrittenNote2.pdf Weakest Precondition-HandwrittenNote3.pdf Lab: Discussion on Agile Process / XP Programming |
Week 8 5/18 5/20 (ICSE) |
Hoare Logic Weakest Precondition and Loop Invariant No class on 5/20. |
Lab:
Bug Reproducing Activity |
Week 9 5/25 Memorial Day 5/27 |
No class on 5/25. Discussion on Modern Code Review and Testing Modern Code Review Practices Model Based Testing Mutation Testing Lecture 14-Code Review and Testing Discussion |
FindBug
Tutorial Lab: Final Project is Due |
Week 10 6/1 6/3 |
Effective Java Creating and Destroying Objects Methods Common to All Objects Classes and Interfaces Exceptions Lecture 15-Effective Java Part 1 Lecture 16-Effective Java Part 2 Final Exam Review Assignment 3 is Due on Wed. |
Code:
Effective Java Code Examples Demonstrated in Class Effective Java Book: Creating and Destroying Objects Methods Common to All Objects Classes and Interfaces Exceptions Generics Sample Final Exams (1) Practice Exam 1 (2) Practice Exam 2 (3) Practice Exam 3 |
Student Projects Video |
Üdder
(Spontaneous Event Schedule and Coordination iOS App, CS
130 Team Project Award Winner) Photo Hangout (Real Time Collaborative Photo Editing Mobile App, Runner Up) Eventful (Spontaneous Event Schedule and Coordination Android App, Honorable Mention, Nice Video) BitBoard (Web App and iOS App for Collaborative Whiteboard Sketching, Honorable Mention) Barter (Improved Craigslist+Tinder like experience for iOS Buy-Sell-Trade) Beat Maker (Real Time Audio Editing Mobile App for Dance Choreography) Book Cycle (Textbook Buy and Sell Web App) Diet&Fit Motivation (Calorie Counting and Fitness Recommendation Web App) Game Set Match (Improved Match.com with Games) Hera (Real Time Music Animation based on Web Audio Characteristics) MMM My Meal Manager (Recipe Suggestions based on Inventory Management) PackManager (Packing Suggestion App for Travels based on Historical Weather Patterns) Pantry (Pantry Inventory Food Expiration Notification) PiCast (Video Streaming using Raspberry Pi) TutorU (Tutor Finding and Payment Web App) Vantage (Social Photo Album Mobile App) |
How Does It Work?
1) Think. The teacher provokes students' thinking with a
question or prompt or observation. The students should take a few
moments (probably not minutes) just to THINK about the question.
2) Pair. Using designated partners (such as with Clock Buddies),
nearby neighbors, or a deskmate, students PAIR up to talk about the
answer each came up with. They compare their mental or written notes
and identify the answers they think are best, most convincing, or most
unique.
3) Share. After students talk in pairs for a few moments (again,
usually not minutes), the teacher calls for pairs to SHARE their
thinking with the rest of the class. She can do this by going around
in round-robin fashion, calling on each pair; or she can take answers
as they are called out (or as hands are raised). Often, the teacher or
a designated helper will record these responses on the board or on the
overhead
You will work in teams of four to six students in the same TA
section. You should demonstrate that the proposed application is new
and a unique creation. If you implement a feature that already exists
or is very similar to an existing feature in any past or later
version, it will be considered as plagiarism. When proposing a
project, you should investigate whether it is feasible to implement
and test it. You are expected to perform a live demonstration of your
project during your project presentations. Students in the same team
will not always receive the same grades, and project grades will
account for individual effort and contribution. In each phase of the
projects, students will rate and rank individual contributions within
the teams and will rate the quality of projects for other teams. The
teaching team will consider these peer evaluation reports when
assigning individual grades. Your TAs will be in charge of
setting project requirements and grading your projects. The
instructor will also attend your midterm and final project
presentations and provide additional assessments of your projects.
Project activities will include the following but not limited to:
During this course, I will be asking you to give me feedback on your
learning in both informal and formal ways, e.g., including anonymous
midpoint survey about how my teaching strategies are helping or
hindering your learning. It is very important for me to know your
reaction to what we are doing in the class, so I encourage you to
respond to these surveys, ensuring that we can create an environment
effective for teaching and learning. Occasionally, at the end of the
lecture, I will hand out index cards to ask "what is the most
important thing you have learned in this class session?" and "what
questions do you still have?" This feedback will be anonymous and this
is to check your understanding and promote Q&A.
Each member of the university is expected to uphold these values
through integrity, honesty, trust, fairness, and respect toward peers
and community. In your first week, you must read and sign UCLA's Academic
Integrity Statement.
Q: Why aren't there many programming assignments? I want to
improve my programming skill through this class.
My goal is to help you experience a software project life
cycle by creating concrete artifacts in each stage. Thus, while
software implementation is an important part of the life cycle, coding
is not the main focus of this class. If you are excited about coding
and want to practice more, please select a project with a significant
implementation component or volunteer to play a key role in
implementing your team project. I can also share pointers to open
source projects, books, and references that could help you to practice
your programming skills further.
Q: Why are we emphasizing theories (such as discrete math,
logic, proof by induction, and program analysis) in a project-based
software laboratory course?
I hope that you can not only get a good job as an entry level software
engineer, but succeed in the future as a lead, principal engineer and
architect. This requires you to have not only a solid coding skill but
a theoretical foundation for systematic design, analysis, testing, and
verification methods. In my opinion, these foundations cannot be
easily attained while you are on the jobs; they are best taught at
University.