This syllabus was adapted from materials courtesy of Profs. Anya E. Vostinar, Amy Csizmar Dalal, & Jeff Ondich.
Instructor: Jean Salac (she/her)
Classroom: Hulings 316
Time: 3a (Mondays & Wednesdays 11:10-12:20pm; Fridays 12-1pm)
Course Schedule: You can find the course schedule and important deadlines here.
Course Staff: TBD
Required Course Materials (All have free access):
I recognize the potential financial burden of additional course materials. If you need assistance to cover course expenses, please reach out to me by Friday of Week 1.
Student Drop-In Hours (also known as Office Hours):
By now, you’ve taken at least a couple of computer science courses. You know how to program. You might know how to program pretty well. But mostly, you’ve done small-ish projects with clear guidelines and clear outcomes. You may wonder, how close is your experience so far to that of those who develop software — to “real world” programming? What do you need to know about how to write software in the real world to be a successful and independent programmer? Further, what do you need to know about how to be ethical in developing software and working with a team and clients?
This course is an introduction to the key concepts of software design, which we’ll loosely define as the art and science of effective and ethical software planning, construction, development, and maintenance. In this class, we’ll focus on the tools, skills, and ideas that good software developers should use in their day-to-day work. The concepts we’ll cover, practice, and discuss will be useful for programs, projects, and teams of any size.
There are five high-level learning goals in this course:
Moodle: All course related materials, assignments, projects, readings, and resources will be posted here.
GitHub Classroom: All starter code for assignments will be distributed here, and your project repositories are hosted here. You will turn in most of your projects on GitHub.
Languages: Python, HTML, CSS, SQL, and Javascript.
IDE: VSCode. You should download VSCode to your personal machine. We’ll also be doing a fair amount of work in text editors and the terminal.
Default environment: I will default to Mac OSX in class for development.
I am committed to the principle of universal learning. This means that our physical and virtual spaces, our practices, and our interactions should be as inclusive as possible. Mutual respect, civility, and the ability to listen and observe others carefully are crucial to universal learning.
I strive to create an inclusive and respectful classroom that values diversity. Our individual differences enrich and enhance our understanding of one another and of the world around us. This class welcomes the perspectives of all ethnicities, genders, religions, ages, sexual orientations, disabilities, socioeconomic backgrounds, regions, and nationalities.
Attendance: Attendance in class is expected (and is part of your grade). A quarter-long team project makes up the most of this class, and much of classtime will be spent working on deliverables that contribute to your team project. If you miss class, you will miss out on that opportunity.
Communication: I expect you to check Moodle every day for updates on activities and assignments. All out-of-class written communication will happen via the class announcement forum. Please make sure you are checking it regularly and/or have email or push notifications setup. Each class day will have preparation assignments for you to complete before class. All materials will be released at least 48 hours before they are due.
Technical Issues: If you experience significant technological problems that limit your ability to participate, please contact the ITS Helpdesk at 507-222-5999 or helpdesk@carleton.edu. For announcements of known technical issues, visit the Helpdesk portal.
Extenuating Circumstances: If your personal situation (due to COVID-19 illness or other circumstances) begins to impact your ability to engage with the course, please let me know and contact the Dean of Students Office.
Student Drop-In Hours: Student drop-in hours are a great time to clear up any lingering confusion you may have about certain concepts, ask about the daily readings and assignments, work through ideas, or just talk about something in the course or in computer science generally or in life that’s piqued your interest. These time slots are for you, so use them! If for whatever reason you cannot make it to my student drop-in hours, feel free to make an appointment to see me (info at the top of this page).
Lab Assistant Hours: Lab assistant hours are another opportunity to clear up any confusion or get help with debugging your code. Lab assistant hours are held in Olin 310 and you can get help for this class whenever there is a lab assistant who is comfortable with helping with CS257 material. The lab assistant schedule, along with the classes they can help with, is posted on the doors of Olin 310 and will be posted on the Moodle site for this class once available. Historically, there have been 10+ lab assistants who can help with CS257 available everyday, except Friday evenings.
Accommodations for Students with Disabilities: Carleton College is committed to providing equitable access to learning opportunities for all students. The Office of Accessibility Resources (Henry House, 107 Union Street) is the campus office that collaborates with students who have disabilities to provide and/or arrange reasonable accommodations. If you have, or think you may have, a disability (e.g., mental health, attentional, learning, autism spectrum disorders, chronic health, traumatic brain injury and concussions, vision, hearing, mobility, or speech impairments), please contact OAR@carleton.edu or call Sam Thayer (’10), Director of the Office of Accessibility Resources (x4464), to arrange a confidential discussion regarding equitable access and reasonable accommodations.
Assistive Technologies: The Assistive Technologies program brings together academic and technological resources to complement student classroom and computing needs, particularly in support of students with physical or learning disabilities. Accessibility features include text-to-speech (Kurzweil), speech-to-text (Dragon) software, and audio recording Smartpens. If you would like to know more, contact aztechs@carleton.edu or visit go.carleton.edu/aztech.
One of my goals for you in this course is for you to continue to develop as an independent programmer and learner. I’m much more interested in what skills and understanding you have mastered by the end of the course than the exact pace at which you master them. However, it isn’t healthy for you or me if you leave everything to the last minute. It also isn’t fair to your team if you haven’t prepared as much as they have. Therefore, my goal with the following evaluation metrics is to balance providing you flexibility to learn at your own pace while also making sure to spread your learning out over the entire term.
Towards that end, your performance in this class will be evaluated in three different ways according to the learning goals for the course:
Each deliverable that you turn in will be evaluated against a checklist of specifications related to one or more of the course learning objectives. I will distribute the checklists I’ll use to assess each deliverable so that you know exactly what constitutes each of these levels. I will rank each learning objective, and the overall submission, according to a four-level scale:
You may revise any team or individual deliverable except for anything due on the last day of classes or finals. Learning is not a linear process, and learning involves making mistakes and learning from them.
In this course, we need to balance flexibility for individuals with structure for teams and the class as a whole. I also want to help you avoid procrastinating to the point that you can’t get everything submitted by the end of the term. Therefore, the late work/extension policy varies depending on the type of work.
All deliverables have a 1-hour grace period after their posted due date and time to account for slight technical delays in submission while allowing evaluation of submissions to start soon after the due date. You must turn in a submission that at least clears "Not Yet Proficient" within the 1-hour grace period from the deadline to be eligible for a revision, so I highly recommend you aim to submit something in the original submission window, even if it isn’t complete, so that you can benefit from feedback and revision.
To earn teamwork credits, you must arrive in class and submit your preparation assignments no more than 5 minutes after the start of the class meeting to account for slight delays while enabling you to be prepared for the class and contribute to the team meeting.
If you’re staring down a deadline that you know you can’t meet, or if you’ve fallen behind, get in touch with me immediately and we’ll make arrangements. While I need to put boundaries in place for my own health and wellness, and for fairness to everyone in the class, I also want to make sure you are progressing in your learning.
Per Carleton policy, all extensions for end of term work need to go through your class dean.
We are in a new age of software design and development (and everything else) with the arrival of generative AI. You will be allowed to use Github Copilot for all programming work, but NOT ChatGPT, Gemini, or other general-purpose LLMs. Github Copilot was trained on and designed to work for code, while general-purpose LLMs like ChatGPT and Gemini were not. Because of the complexity of quarter-long team project, past students who have used code from general-purpose LLMs spent more time debugging LLM output than the time it would have taken them to just write the code themselves based on the starter code from me. We will spend time as a class exploring where these tools are useful and where they might not actually be helpful.
Computer Science is a collaborative discipline, & people who apply computer science concepts and skills both shape and are shaped by social, political, & cultural environments beyond themselves. You are encouraged to collaborate with your classmates to learn, but collaboration comes with additional repsonsibilities:
# Method to decide how much financial aid students should receive
# I used this StackOverflow post to refresh on the syntax for writing conditional statements in Python: https://stackoverflow.com/link-to-post
Per Carleton policy, I am required to report cases of suspected academic dishonesty to the Dean's office.