1;95;0c CMSC 330, Spring 2021

C   M    S    C    3   3   0
Organization of Programming Languages,
Spring 2021

Instructors

Name Section Office E-mail Office Hours
(also available by appointment)
Anwar Mamat Section 010X Online Email TuTh 2:00-3:00
2/16 Tu OH moved to 2/17 4:00-5:00pm
04/08 OH canceled.
Mike Hicks Section 020X Online mwh@cs.umd.edu Tu 3:30-4:30pm, Th 9-10am
except no 2/16 OH -- Wed 2/17 4:30-5:30pm instead

TAs

Name E-mail
Vinnie Caprarolavcapra1@terpmail.umd.edu
Pavan Ravindrapravin@terpmail.umd.edu
Murat Ablimitmablimit@umd.edu
Guido Ambaszgambasz@terpmail.umd.edu
Cliff Bakaliancbakalia@umd.edu
James BrunnerJbrunner@umd.edu
Ankit Chandnaniankitc@terpmail.umd.edu
Olasubomi Efuniyioefuniyi@terpmail.umd.edu
Alex Engaveng731@terpmail.umd.edu
Jonah Freemanjfreem@umd.edu
Vyoma Janivjani@umd.edu
Xuewei Jicamellia@terpmail.umd.edu
Rhys Kittlesonrkittles@terpmail.umd.edu
George Kleesgklees@umd.edu
Saideep Kuchibhotlaskuch@terpmail.umd.edu
Bert Lovewlove@umd.edu
Noah McCordnmccord@umd.edu
Nikhil Pateelnpateel@umd.edu
Deena Postoldpostol@terpmail.umd.edu
Naveen Ramannraman1@umd.edu
Minya Rancicmrancic1@umd.edu
John Richardsjricha15@umd.edu
Shilpa Roysroy4899@umd.edu
Suteerth Vishnusvishnu@umd.edu
Matthew Woernermwoerner@terpmail.umd.edu
Elisheva Zakezak@umd.edu
Michael Stephanusmstephan@terpmail.umd.edu

Information

Lectures Section 010x: TuTh 11:00am-12:15pm (Eastern Time) Online
Section 020x: TuTh 2:00pm-3:15pm (Eastern Time) Online
Midterm 1 March 4th (Online, during class time)
Midterm 2 April 15th (Online, during class time)
Final May 13th 4:00pm-6:00pm Online
Textbooks There are no required or recommended texts. See the resources page for useful online links.

Discussions

All sections are online. Discussions will be pre-recorded and available for you to watch each Friday.

Office Hours: (Online) (Office hour queue app)

Time (Eastern)MTWTF
9:00 Yixuan
Suteerth
James
Matthew G
Vyoma

Yixuan
Suteerth
Pavan

Shilpa
Suteerth
James

Yixuan
Suteerth
Matthew G

Yixuan
Shilpa
Guido
10:00 Yixuan
Suteerth
James
George
Nikhil

Yixuan
Suteerth
Pavan
Shilpa
Suteerth
Pavan
Guido
Elisheva

Yixuan
Suteerth
Matthew G
Yixuan
Shilpa
Guido
Elisheva
11:00 Yixuan
Suteerth
Vyoma
Nikhil
Murat
Yixuan
Clifford
Vyoma
Elisheva
Shilpa
Suteerth
Pavan
Guido
Elisheva

Yixuan
Clifford
Vyoma
Yixuan
Shilpa
Melissa
Pranav
Murat
12:00 Murat
Saideep
Olasubomi
Katie
William (Bert)

Clifford
Vyoma
Matthew G
Katie
Pavan
James
Olasubomi
Pranav
Clifford
Vyoma
Mihailo
Elisheva
Olasubomi
Shilpa
Melissa
Pranav
Murat
1:00 James
Ankit
Saideep
Olasubomi
Nikhil

Vincent
Clifford
Alexander
Katie
Vincent
Pavan
Olasubomi
Michael
Clifford
Pranav
Alexander
Elisheva
Olasubomi
Melissa
George
Pranav
Murat
2:00 Ankit
Xuewei
William (Bert)
Mark
Pranav

Vincent
Alexander
Matthew W
Henry
Vincent
Saideep
Olasubomi
Michael

Alexander
Matthew W
Melissa
Olasubomi
Ankit
Xuewei
William (Bert)
James
3:00 Xuewei
Mark
Matthew W
Jonah
Saideep

Vincent
Henry
Matthew W
Vincent
Henry
William (Bert)
Olasubomi

Naveen
Matthew W
Henry
Olasubomi
Nikhil
Ankit
Xuewei
William (Bert)
4:00 Jonah
Katie
Xuewei
Mark
George

Henry
Rhys
Matthew W
Katie
Olasubomi
Henry
Naveen
Michael

Henry
Rhys
Naveen
Olasubomi
Henry
Nikhil
Xuewei
Ankit
5:00 Jonah
George
Ankit
Alexander
Melissa

TA MEETING -
NO OFFICE HOURS
Jonah
Katie
Mark
Naveen
Michael
Saideep
Matthew G
Mihailo
Shruti
Nikhil
Saideep
Naveen
Matthew G
6:00 Henry
Jonah
Melissa
Shruti
Alexander

Henry
Rhys
Naveen
Jonah
Shruti
Mark
William (Bert)
Michael

Henry
Mihailo
Murat
Mark
Henry
Shruti
Rhys
Michael

Class announcements will be posted via Piazza; please check the course Piazza page daily. You may sign up for the class on Piazza here.

A study of programming languages, including their syntax, semantics, and implementation. Several different models of languages are discussed, including procedural (Ruby), functional (OCaml), and object-oriented (Java). Language features such as formal syntax, scoping and binding of variables, higher-order programming, typing and type polymorphism, and object inheritance are explored.

Date Lecture
Jan 26 Introduction
Ruby Basics
Jan 28 Ruby Classes, Arrays and Hashes
Feb 2 Ruby Regular Expressions
Feb 4 Ruby Codeblocks, Exceptions
Equality, Mixin Inheritance, Miscellany
Feb 9 OCaml Basics
Feb 11 OCaml Lists and Pattern Matching
Feb 16 Lets, Tuples, and Records
Feb 18 Higher Order Functions (map, fold)
Feb 23 Datatypes
Property-based Testing
Feb 25 Tail Recursion
Closures
Mar 2 Closures
Imperative OCaml (updated 3/9)
Mar 4Midterm 1
Mar 9 Regexes and Finite Automata
Mar 11 NFAs and DFAs (updated 3/23)
Mar 23 Context Free Grammars
Mar 25, 30 Parsing (small update 4/7)
parser example
Expression parser example
Apr 1 Operational Semantics
Code example
Apr 6 Software Security I
Buffer overflows, command injection
Apr 8 Software Security II
WWW security (SQL injection, Cross-site scripting)
Apr 13 Rust Basics
and part of Ownership, Lifetimes, and References
Apr 20 Rust Ownership, Lifetimes, and References and Collections
Apr 22 Rust Structs, Enums and Traits
Apr 27 Rust Box Smart Pointer, Trait Objects and Interior Mutability
Apr 29 Lambda Calculus Basics
May 04 Lambda Calculus Encodings
May 06 Memory Management
Type Systems
May 11 History of Programming Languages
Projects will be posted on the class GitHub.

This schedule is subject to change.

Project Release Date Due Date
Project 0 Setup 01-26 02-10
Project 1a Ruby Warmup 01-26 02-03
Project 1b Battleship game 02-01 02-10
Project 2a OCaml Warmup 02-10 02-22
Project 2b OCaml Higher Order Functions and Data 02-22 03-08 03-10
Project 3 Regular Expression Engine 03-09 03-30
Project 4a MicroCaml Lexer and Parser 03-30 04-08 recommended, 04-12 latest for full points
Project 4b MicroCaml Interpreter 04-08 04-22
Project 5a Rust Warmup 04-21 04-29
Project 5b Rust: Turtles for sale! 04-29 05-11
Syllabus subject to change until the start of the semester
Prerequisites: Prerequisites: C- or better in CMSC 216 and CMSC 250
Credits: 3 credits

A study of programming languages, including their syntax, semantics, and implementation. Several different models of languages are discussed, including dynamic, scripting (e.g., Ruby, Python) functional (e.g., OCaml, Haskell, Scheme), and concurrent/parallel (an aspect of many languages). Language features such as formal syntax, scoping and binding of variables, higher-order programming, typing and type polymorphism, and concurrent language features will be explored.

List of Topics (subject to change)

The following list of lecture topics will vary according to the pace of lecture.
  • Dynamic Languages (Ruby)
    • Implicit vs. explicit declarations
    • Dynamic vs. static typing
    • Text processing and string manipulation
  • Regular expressions and finite automata
  • Context-free grammars and parsing
  • Functional programming (OCaml)
    • Lists and recursion
    • Type inference and polymorphism
    • Higher-order functions and closures
    • Static (lexical) vs. dynamic scoping
    • Modularity and abstraction
  • Software security
    • Design anti-patterns that lead to security flaws
    • Defenses against security attacks
  • Advanced Topics
    • Lambda calculus
    • Operational Semantics
    • Garbage collection and memory management
    • History of Programming Languages

Grading

Grades will be maintained on the CS Department grades server. You can always see your current grade here.

You are responsible for all material discussed in lecture and discussion section and posted on the class web page, including announcements, deadlines, policies, etc. During the semester we may provide ungraded practice homework exercises and solutions. While we will not collect these exercises, completing them is essential preparation for exams. You may work together on these ungraded homeworks, and you may of course come to office hours for additional help.

Your final course grade will be determined according to the following percentages:

Assignment Percentage
9 Programming Projects
  • Each project (e.g. P1a) is 5%, except P3 which is 8%, and P5b, which 4%.
47% Total
Free point1% Total
4 Quizzes
  1. OCaml (02/26)
  2. DFA, NFA (03/26)
  3. OpSem, Parsing, CFG (04/09)
  4. Lambda Calc (05/07)
8% Total
Clicker Quizzes 4% Total
2 Midterms 10% Each
Final 20%

Any request for reconsideration of any grading on coursework must be submitted within one week of when it is returned (or published on gradescope). Exam regrading requests must be made through gradecscope. Any coursework submitted for reconsideration may be regraded in its entirety, which could result in a lower score if warranted.

Final course grades will be curved as necessary, based on each student's total num score for all coursework at the end of the semester. But: It is very likely that 90 and above earns an A, 80-90 earns a B, 70-80 earns a C, etc.; the curve will only lower the cutoffs, not raise them. Important: Completing the programming assignments is an essential part of the course. Therefore, we may fail any student who does not make a good-faith attempt on all course projects, regardless of the student's performance or scores on the other coursework. We will define good-faith attempt as achieving at least 20 percent on the gradescope server for each project. To obtain these points you may submit solutions past the late deadline.

Programming Projects

Projects must be submitted electronically following the instructions given in class. Projects may not be submitted by any other means (e.g., please do not email your projects to us). It is your responsibility to test your program and verify that it works properly before submitting. All projects are due at 11:59pm on the day indicated on the project assignment, according to the gradescope server's internal clock.

Projects may be submitted up to 24 hours late for a 10% penalty. For example, a project that would earn 90 points for an on-time submission will earn 81 (which is 90 times 0.90) if submitted late. Note that your project score as it appears on the project submission (gradescope) server will not include any late penalties. Any penalties will be incorporated into the final project grade on the grade server. If you submit both on-time & late, your project will receive the maximum of the penalty-adjusted scores.

Project extensions will not be granted due to system problems, network problems, power outages, etc., so do not wait to submit a project until the night it is due. You may submit multiple times up to the deadline, and only your last on-time submission is graded. Similarly, if you submit late, only your last submission before the deadline will be graded. No consideration in grading will be made for errors made in transferring files or submitting the wrong version of your project. Having a working, unsubmitted version will not count; only submitted code will be counted.

Your projects will be graded based on test cases not provided in advance. Because grading is done automatically, you must follow the project specification exactly. Also, while projects will generally not be graded on style or documentation, we reserve the right to manually grade program source code for some projects.

Finally, any "hard coding" in a project assignment may result in a score of zero for that project, and is considered a bad-faith effort. Hard coding refers to attempting to make a program appear as if it works correctly, when in fact it does not. One example of hard coding would be printing the desired output instead of computing it. This is only one example, and if you have any questions as to what constitutes hard coding, be sure to ask ahead of time.

Do not share or publicly post your project solutions on-line; doing so constitutes a violation of academic integrity. This issue is discussed in greater detail below.

Clicker Quizzes

Clicker quizzes will be given in-class during lectures. Effective August 22, 2017, students and faculty at UMD have access to TurningPoint (Clickers) mobile license subscriptions at NO cost. You can use the phone app. You also have to register your device. Please follow the instructions here:Instructions Register a TurningPoint Account for New Students

Outside-of-class communication with course staff

We will interact with students outside of class in primarily three ways: in-person during office hours, electronically via the web forum and course web page, and electronically via e-mail. The large majority of communication should employ the first two methods, reserving e-mail for personal (presumably rare) circumstances.

Personalized assistance, e.g., with programming assignments or exam preparation, will be provided during office hours. You are responsible for developing and debugging your own programs. Do not rely on the instructional staff to make your project work. Lower-level CMSC courses provide extensive debugging and development help in office hours, but upper-level CMSC courses expect students to complete projects with minimal extra help. Therefore in CMSC 330, we will provide less debugging help than some students may be used to. If you come in with a question, expect to be pointed in the right direction, but it will be up to you to finish solving the problem on your own. Office hours for the instructional staff will be posted on the course web page a few days into the semester.

Additional assistance will provided via the Piazza web forum. You may use this forum to ask general questions of interest to the class as a whole, e.g., administrative issues or project clarification questions. The course staff will monitor piazza on a daily basis, but do not expect immediate answers to questions. Please do not post publicly any information that would violate the university academic integrity policy (e.g., project code or test cases).

Piazza allows students to post private questions that are only visible to instructors. Please use this feature if you wish to ask specific questions concerning your project solutions. Generally it will also be helpful to submit your current project code to the submit server, so instructors & TAs can try running your code on their machines before answering your questions.

Personal e-mail to instructors or TAs should be reserved for issues that cannot be handled by the above methods.

Important announcements will be made in class or on the class web page, and via piazza.

Excused Absences

Any student who needs to be excused for an absence from a single lecture, recitation, or lab due to illness shall:

  1. Make a reasonable attempt to inform the instructor of his/her illness prior to the class.
  2. Upon returning to the class, present their instructor with a self-signed note attesting to the date of their illness. Each note must contain an acknowledgment by the student that the information provided is true and correct. Providing false information to University officials is prohibited under Part 9(h) of the Code of Student Conduct (V-1.00(B) University of Maryland Code of Student Conduct) and may result in disciplinary action.

Missing an exam for reasons such as illness, religious observance, participation in required university activities, or family or personal emergency (such as a serious automobile accident or close relative's funeral) will be excused so long as the absence is requested in writing at least 2 days in advance and the student includes documentation that shows the absence qualifies as excused; a self-signed note is not sufficient as exams are Major Scheduled Grading Events. For this class, such events are the final exam, the two midterms, and quizzes, which will be given in class.

For medical absences, you must furnish documentation from the health care professional who treated you. This documentation must verify dates of treatment and indicate the timeframe that the student was unable to meet academic responsibilities. In addition, it must contain the name and phone number of the medical service provider to be used if verification is needed. No diagnostic information will ever be requested. Note that simply being seen by a health care professional does not constitute an excused absence; it must be clear that you were unable to perform your academic duties.

It is the University's policy to provide accommodations for students with religious observances conflicting with exams, but it is the your responsibility to inform the instructor in advance of intended religious observances. If you have a conflict with one of the planned exams, you must inform us prior to the end of the first two weeks of the class.

For missed exams due to excused absences, the instructor will arrange a makeup exam. If you might miss an exam for any other reason other than those above, you must contact the instructor in advance to discuss the circumstances. We are not obligated to offer a substitute assignment or to provide a makeup exam unless the failure to perform was due to an excused absence.

The policies for excused absences do not apply to project assignments. Projects will be assigned with sufficient time to be completed by students who have a reasonable understanding of the necessary material and begin promptly. In cases of extremely serious documented illness of lengthy duration or other protracted, severe emergency situations, the instructor may consider extensions on project assignments, depending upon the specific circumstances.

Besides the policies in this syllabus, the University's policies apply during the semester. Various policies that may be relevant appear in the Undergraduate Catalog.

If you experience difficulty during the semester keeping up with the academic demands of your courses, you may consider contacting the Learning Assistance Service in 2201 Shoemaker Building at (301) 314-7693. Their educational counselors can help with time management issues, reading, note-taking, and exam preparation skills.

Students with Disabilities

Students with disabilities who have been certified by Disability Support Services as needing any type of special accommodations should see the instructor as soon as possible during the schedule adjustment period (the first two weeks of class). Please provide DSS's letter of accommodation to the instructor at that time.

All arrangements for exam accommodations as a result of disability must be made and arranged with the instructor at least three business days prior to the exam date; later requests (including retroactive ones) will be refused.

Academic Integrity

The Campus Senate has adopted a policy asking students to include the following statement on each examination or assignment in every course: "I pledge on my honor that I have not given or received any unauthorized assistance on this examination (or assignment)." Consequently, you will be requested to include this pledge on each exam and project. Please also carefully read the Office of Information Technology's policy regarding acceptable use of computer accounts.

Programming projects are to be written individually, therefore cooperation or use of unauthorized materials on projects is a violation of the University's Code of Academic Integrity. Both the person receiving assistance and the person providing assistance are in violation of the honor code. Any evidence of this, or of unacceptable use of computer accounts, use of unauthorized materials or cooperation on exams or quizzes, or other possible violations of the Honor Code, will be submitted to the Student Honor Council, which could result in an XF for the course, suspension, or expulsion.

  • For learning the course concepts (including the programming languages), students are welcome to study together or to receive help from anyone else. You may discuss with others the project requirements, the features of the programming languages used, what was discussed in class and in the class web forum, and general syntax errors. Examples of questions that would be allowed are "Does a Java class definition end in a semicolon?" or "What does a 'class not found' error indicate?", because they convey no information about the contents of a project.
  • When it comes to actually writing a project assignment, other than help from the instructional staff a project must solely and entirely be your own work. Working with another student or individual, or using anyone else's work in any way except as noted in this paragraph, is a violation of the code of academic integrity and will be reported to the Honor Council. You may not discuss design of any part of a project with anyone except the instructor or teaching assistants. Examples of questions you may not ask others might be "How did you implement this part of the project?" or "Please look at my code and help me find my stupid syntax error!". You may not use any disallowed source of information in creating either their project design or code. When writing projects you are free to use ideas or short fragments of code from published textbooks or publicly available information, but the specific source must be cited in a comment in the relevant section of the program.

Violations of the Code of Academic Integrity may include, but are not limited to:

  1. Failing to do all or any of the work on a project by yourself, other than assistance from the instructional staff.
  2. Using any ideas or any part of another person's project, or copying any other individual's work in any way.
  3. Giving any parts or ideas from your project, including test data, to another student.
  4. Allowing any other students access to your program on any computer system.
  5. Posting solutions to your projects to publicly-accessible sites, e.g., on github. (Note that if you want to use Git, you can request free, private accounts from Bitbucket.)
  6. Transferring any part of a project to or from another student or individual by any means, electronic or otherwise.

If you have any question about a particular situation or source then consult with the instructors in advance. Should you have difficulty with a programming assignment you should see the instructional staff in office hours, and not solicit help from anyone else in violation of these rules.

It is the responsibility, under the honor policy, of anyone who suspects an incident of academic dishonesty has occurred to report it to their instructor, or directly to the Honor Council.

Every semester the department has discovered a number of students attempting to cheat on project assignments, in violation of academic integrity requirements. Students' academic careers have been significantly affected by a decision to cheat. Think about whether you want to join them before contemplating cheating, or before helping a friend to cheat.

You are welcome and encouraged to study and compare or discuss their implementations of the programming projects with any others after they are graded, provided that all of the students in question have received nonzero scores for that project assignment, and if that project will not be extended upon in a later project assignment.

Course Evaluations

If you have a suggestion for improving this class, don't hesitate to tell the instructor or TAs during the semester. At the end of the semester, please don't forget to provide your feedback using the campus-wide CourseEvalUM system. Your comments will help make this class better. CourseEvalUM is scheduled to be open between Tuesday, December 1 and Sunday, December 13, but this is subject to change by campus.

Right to Change Information

Although every effort has been made to be complete and accurate, unforeseen circumstances arising during the semester could require the adjustment of any material given here. Consequently, given due notice to students, the instructors reserve the right to change any information on this syllabus or in other course materials.

Copyright

All course materials are copyright Dept. of Computer Science, University of Maryland (Marvin Zelkowitz, Jeff Foster, Larry Herman, Atif Memon, Chau-Wen Tseng, Michael Hicks, David Levin, Nelson Padua-Perez,Anwar Mamat). All rights reserved. Students are permitted to use course materials for their own personal use only. Course materials may not be distributed publicly or provided to others (excepting other students in the course), in any way or format.

Quick Reference

Ruby

  • ruby-lang.org - The main Ruby website.
  • Quick Start (Ruby in 20 minutes)
  • Introduction to Ruby - A simple introduction to basic Ruby
  • PythonTutor for Ruby - An interactive, web-based visual debugger for Ruby programs
  • The Pragmatic Programmer's Guide - "The Pickaxe Book" is a more comprehensive overview of Ruby. It's an online version of the first edition of a printed Ruby book. The only thing to keep in mind is that it covers Ruby 1.6, while you can buy the newest printed version which covers the Ruby 1.9 and 2.0. We probably won't do anything for this course where the difference between versions. There's a lot of information here which you won't need- the most relevant sections are the first fourteen listed (the first up through "Basic Input and Output"), then "When Trouble Strkes", "Ruby and Its World", and "The Ruby Language" and "Classes and Objects". These last two are good summary references for the language.
  • Ruby Class Reference
  • Ruby documentation - A list from ruby-lang.org of Ruby reference manuals, online sources of Ruby information (some of the ones which will probably be more useful are mentioned specifically below), and Ruby articles. If you want to buy a printed book about Ruby several are listed.
  • Ruby User's Guide - An English translation of a book written by the designer of the language. More of a language reference than a tutorial.

OCaml

Rust

Formal grammars and finite automata

Lambda calculus

Java Garbage Collection

Ruby On Rails

  • Rails is a full-stack framework for developing database-backed web applications according to the Model-View-Control pattern.

Git

 

Other relevant texts

Previous required texts for CMSC 330 have chapters on relevant topics covered in this course. If the lecture notes are insufficient, look for these books. They should be available in the university library.

  • Concepts of Programming Languages (Seventh Edition) by R. Sebesta, Addison Wesley (2006) (ISBN 0-321-33025-0).
  • Programming Languages: Design and Implementation (Fourth Edition) by T. Pratt and M. Zelkowitz, Prentice Hall (2001) (ISBN 0-13-027678-2).
  • O'Reilly History of Programming Languages Poster