CSE 110 Software Engineering

Welcome to CSE 110 Software Engineering!  We love building great software, and want to help you become great software engineers.

Class Meetings

LECTURE:     Monday-Wednesday-Friday 1:00-1:50pm [podcast tbd]

LAB:             Wednesday 11:00am-1:00pm, CSE Basement, rooms B240, B250, B260
                   (extended lab period is 10am-1pm, and staff will be available)

DISCUSSION: Monday 4:00 - 4:50pm, Center 216
                    Monday 5:00 - 5:50pm, Center 216

FINAL:          Thursday, June 9, 11:30am - 2:30pm


Course Description

The construction of good software systems is challenging. In this course you will get an introduction to software development and engineering methods, including specification, design, implementation, testing, and process.  There is an emphasis on team development, agile methods, and use of tools such as IDE's, version control, and test harnesses.

Course Requirements and Grading

  • Grading elements [in percent, subject to change before 3/28]:
    • pre-class reading quizzes [5%]
    • clicker participation [5%]
    • quizzes (mostly in class) [10%]
    • labs [10%]
    • project [35%]
    • final [35% - and you must pass final to pass the course (60% on final)]

  • Pre-Class Reading Quizzes:  You are expected to do the reading assigned for each class period, in advance.  (No reading will be assigned on in-class quiz days.)  Before each class, there will be a simple online quiz to check your preparation for class.  We will drop the lowest 3 reading quizzes.  You can take a quiz up to a 1/2 hour before class starts on Monday/Friday and until 10am on Wednesday.
  • Clicker Participation: Your clicker grade is the proportion of the number of clicker questions in which you participate.  We will drop 20% of non-participations.  That is, someone who participates in 80% of the clicker questions will receive 100% credit for clicker participation.  There will be no extra credit [see: wikipedia, youtube], but first-day clicker participation will be counted towards your participation, but not in clicker question count.

  • Quizzes:  There will be 5 in-class quizzes and 1 online quiz during the quarter.  The in-class quizzes will be given every second Monday (even-numbered weeks in Moodle), in class.  A quiz may be postponed due to extraordinary circumstances - holiday, technology failures, etc.  You are responsible for attending the quiz no matter what day it is actually offered.  The online quiz is during week 1, and regards the mechanics of the course. Your lowest two quizzes will be dropped.  The quizzes are in essence a midterm spread out over several weeks.  This gives you a week-by-week measure of how you are learning in the course, avoiding a costly surprise mid-quarter.

  • Labs: There will be several labs throughout the quarter.  Labs are performed in pairs.  Labs are graded pass/fail (100/0), and are checked off by a TA face-to-face in lab.  If you cannot make the lab time, or need more time than 2 hours, you can complete the lab anytime before the next lab time (10am of the following week).  Note also that we have extended the lab time to provide more flexibility and contact time with the team.
  • Project:  The project concerns constructing an Android application in two phases (each ending in a milestone) throughout the quarter.  You do not need to have an Android device (but can be bought used cheaply).  The application will be run (and tested) inside an Android emulator.  Each phase will be worth the same amount.  Grading will be based on your application's run-time behavior, plus other project considerations (e.g., test cases, design, teamwork, etc.).  We will require that some design-based work products be turned in prior to the end of each phase, which is when the code product is due.  The project will start a couple weeks into the quarter, once we have a few key readings, lectures, and labs under our belts.

UCSD E-Mail and Piazza Forum Requirement

Occasionally we may need to contact you regarding your homework or some pressing matter.  We may use e-mail, and when we do, we will use your official UCSD e-mail address, as registered in TritonLink.  You are responsible for reading course-related e-mails sent to your UCSD account in a timely manner.

We also post important announcements to the Spring 2016 CSE 110 Piazza Forums.  Your should keep yourself subscribed to these forums so that you automatically receive forum posts as an e-mail.  Note that there is a mobile client for Piazza.  Assignments, lecture slides, etc. will be posted to the Spring 2016 CSE 110 Moodle [TBD].  You are responsible for all the content there.

Please see the Team page tab for additional information about communicating with the CSE 110 staff.

Textbooks, iClickers, Moodle and other Resources

We will be using iClickers fairly extensively in the classroom, and they are a graded element of the course.  The bookstore has these in stock.  If you have an older iclicker, that's OK.  You don't need the newer model.

CSE Moodle (csemoodle.ucsd.edu) will maintain the weekly calendar of activities and the resources that go with them, including project resources.  It also hosts online quizzes and grades.  We will not always post on Piazza when something is added there, as many additions are regular (e.g., reading quizzes, lecture slides).

All of the required texts and most of the recommended texts are available online (on campus or via the UCSD web proxy), up to 20 readers at a time.  While this number of licenses has been adequate in the past, this quarter the number of students enrolled is quite large.  You should buy the first two required texts (HFSD and HFDP); these will be great references in the future, as well.  The acronym tags listed in front of the readings below will be used to assign readings, which are required to be completed before class.  From time to time we may also assign a web resource or video to watch.

NOTE: Page numbers may vary between paper and digital versions.  Unless otherwise indicated, page numbers are from the paper edition.  Please use Chapter and Section names to disambiguate as necessary.

Mandatory Class Texts

[HFSD] Dan Pilone, Russell Miles: Head First Software Development, O'Reilly Media, 2007 [online]

[HFDP] Eric Freeman, Elisabeth Freeman, Kathy Sierra, Bert Bates: Head First Design Patterns, O'Reilly Media, 2004 [online]

Recommended Class Texts

[AND] Zigurd Mednieks, Laird Dornin, G. Blake Meike, and Masumi Nakamura:  Programming Android: Java Programming for the New Generation of Mobile Devices, 2nd edition, O'Reilly Media, 2012. [online]

[JIAN] David Flanagan: Java in a Nutshell, fifth edition, O'Reilly, 2005  [online] (this is a great reference book, but if you have another, that's OK)

David Flanagan: Java Examples in a Nutshell, third edition, O'Reilly Media, 2004 [online]

Y. Daniel Liang, Absolute Java for Intro to Java Programming, Comprehensive Version (10th Edition), 2014.  (any Java textbook will do, however)

Academic Integrity

You are to do your own work in this course.   Each student is responsible for knowing and abiding by UCSD's policies on Academic Dishonesty and on Student Conduct. Any student violating UCSD's UCSD Academic Integrity Policy will be reported to the Academic Integrity Office for administrative processing, and may result in suspension or dismissal from UCSD, as well an an academic sanction that could result in failing the course (e.g., a grade of zero (0) on a compromised assignment).  Committing acts that violate the UCSD Student Conduct Code that result in course disruption will be referred to the Office of Student Conduct, and could result in suspension or dismissal.

As a clarification of the UCSD Academic Integrity Policy as it applies to the work in this course, note the following:

  • No student shall provide their assignments, in part or in total, to any other student in current or future classes of this course. No student shall procure or accept assignments from any other student from current or prior classes of this course.

  • All programming code and documentation submitted for evaluation or existing inside the student's computer accounts must be the student's original work or material specifically authorized by the instructor. The course accounts are authorized for course work only.

  • Collaborating with other students to develop, complete or correct course work is limited to activities explicitly authorized by the Instructor. Use of other student's course work, in part or in total, to develop, complete or correct course work is unauthorized. However, students may freely discuss their work with others.

  • Each student must retain intermediate work as proof that submitted work is his or her own. A student may be asked to provide these intermediate copies as evidence that the submitted work is the student's.

  • With regard to the above rules, it is understood that project teams will be sharing code among themselves (but not to other teams) to complete their projects.

  • With regard to the above rules, it is acceptable to search the internet to solve programming problems of the "how to" and bug type.  You are responsible for not violating copyright laws when taking code solutions that are found on the internet.  If you cannot ascertain that copying is permitted, you cannot copy the code, but must, at worst, fashion your own solution based on the solution you have found.