CSE 331 Project
Fall 2024
Details and motivations for the project.
Motivation
CSE 331 is primarily concerned with the technical aspects of algorithms: how to design them and then how to analyze their correctness and runtime. However, algorithms are pervasive in our world and are commonplace in many aspects of society. The main aim of the project is to have you explore some of the social implications of algorithms.
Just to give some examples for such implications:
- Big data is hot these days and there is a (not-uncommon) belief that by running (mainly machine learning) algorithms on big data, we can detect patterns and use those to potentially make policy decisions. Here is a cautionary talk:
- For a longer documentary on the societal impacts of algorithms in general (and specifically machine learning), see Coded Bias :
You can watch the movie on Netflix .
- Another aspect of the effect on technology in society stems from unequal access to technology. In CSE 331 this fall, we will touch upon the issue of access to high-speed Internet a few times, and the project will be motivated by the topic of high-speed Internet. For a primer on the issues regarding unequal access to high-speed Internet, see the following webinar:
(Click on the image above and then check out the recording (the access code is in the linked webpage). I attended the webinar and found it to be very eye-opening.)
Acknowledgment
The development of this project was supported by a Mozilla Responsible Computer Science award . The support is gratefully acknowledged.
The project has three parts
Your project will have three parts:
- Do five programming problems that involve making tradeoffs between various choices, some of which have ethical dimensions. This will be a group assignment.
- Each programming question will be paired with (a series of) reflection questions that involve you writing down and reflecting on some of the design decisions you made in the corresponding programming problem. In particular, these questions will ask you to reflect on the societal and ethical implications of your decisions. This will also be a group assignment.
- At the end of the project, each group member will fill in a survey rating their own and the other group members' contribution to the project.
More details
The main project page has all the details.
Before we give more details on the programming problems, reflection questions and survey aspects of the project, we present details on some logistics: in particular, the deadlines and details on forming a group.
Logistics
We begin by collecting all the relevant deadlines and then giving details on forming groups.
Deadlines
For your convenience, below are all the relevant deadlines (please plan accordingly). The deliverables are due by 11:59pm of the due date.
Deliverable | Due Date |
Team Composition | September 20 |
Team Registration (on Autolab) | September 30 |
Problem 1 Coding | November 1 |
Problem 1 Reflection | November 4 |
Problem 2 Coding | November 1 |
Problem 2 Reflection | November 4 |
Problem 3 Coding | November 25 |
Problem 3 Reflection | December 2 |
Problem 4 Coding | December 6 |
Problem 4 Reflection | December 10 |
Problem 5 Coding | December 6 |
Problem 5 Reflection | December 10 |
Survey | December 10 |
Forming groups
You form groups of size exactly three (3) for the project. Below are the various logistics:
- You have two choices in forming your group:
- You can form your group on your own: i.e. you can submit the list of EXACTLY three (3) group members in your group.
Note
Note that if you pick this option, your group needs to have exactly THREE (3) members. In particular, if your group has only two members, you cannot submit as a group of size two. If you do not know many people in class, feel free to use Piazza to look for the third group member.
Also, if you form a group of size three, please make only one submission per group.
- You can submit just your name, and you will be assigned a random group among all students who take this second option. However, note that if you pick this option, you could end up in a group of size $2$. There will be at most two groups of size $2$.
Potential risk
Note that if you pick the option of being assigned a random group, you take on the risk that a assigned group might not "pull their weight." We unfortunately cannot help with such aspects of group dynamics. (Of course if a group member is being abusive, please do let Atri know.) Please note that a group member who does not do much work will get penalized on the individual component of the project grade.
- You can form your group on your own: i.e. you can submit the list of EXACTLY three (3) group members in your group.
-
Submitting your group composition
Use this Google form to submit your group composition (the form will allow you to pick one of the two options above).
- You need to fill in the form for group composition by 11:59pm on Friday, September 20.
-
Deadline is strict!
If you do not submit the form for group composition by the deadline, then you get a zero for the entire project.
Registering your group on Autolab
New Step in Fall 2024!
As of this semester, once you have filled in the Google form for group composition, once your groups are formed, you will also need to register your group on Autolab. See the project Autolab page for more details, including the relevant dates!
Deadline for group registration is strict!
If you do not register your group by 11:30pm, Monday September 30, then the ENTIRE group will get a zero for the entire project.
Coding Component
In the coding component of the project, you will be developing and implementing algorithms in a scenario that is heavily influenced by a real-life case study.
Your task
Your goal is to solve five programming problems and this has to be done in a group of size 3. These will be set up in a similar manner to programming questions on the homeworks and will be due on Autolab.
How is this different from programming question on the homeworks?
Below we have listed some major ways in which this coding component will be different from programming questions on homeworks:
- First, unlike the HW programming questions, here you can collaborate with your group members.
- The coding component will be much harder than HW programming questions. For one, for most problems in the coding project, there will be no known optimal algorithm. The fact that you can collaborate with others is to help you think beyond the algorithms we have seen in class.
- To reflect the amount of work that might need to go into the coding project, it will be worth $8\%$ (assuming your individual component fractional score $\rho=1$) of your total grade.
- Unlike HW programming questions, where you solve isolated problems, for the coding project you will work on five related problems, where your solutions for previous problems could be relevant to solving the latter problems.
- Unlike the HW problems, in coding project, your algorithm will have to handle multiple competing constraints and your solution will be graded based on how well you can handle various competing constraints.
- Some of the constraints in the problems will be related to societal and ethical considerations.
Reflection Component
In the reflection component of the project, you will be reflecting on the choices you made in the coding component as well as the implications of your choices.
Your task
Your goal is to answer essay-type questions for design choices you make in the five programming problems. This has to be done as a group of size 3. These will be different from the written/proof-based questions on the homeworks and will be due on Autolab.
How is this different from questions on the homeworks?
Below we have listed some major ways in which this reflection component will be different from questions on homeworks:
- These questions will be quite unlike other questions y'all answer in 331. In particular, these would be essay-type questions where you will need to write down in English the design choices you made in your code as well as reflect on how your design choices affects others.
- These questions are intended to make you think about the societal and ethical considerations of the design choices you make in your code.
-
There is no single "right" answer
A big difference in the reflection component from pretty much everything else in the course is that there is no single right answer. These answers by their nature are subjective. In particular, unlike the other questions in the course, there can be multiple "right" answer and in some sense there is no "wrong" answer.
Since the grading of such answers can be subjective to ensure consistent grading, Atri will be grading all these submissions.
- The open-endedness of these questions might be a bit unnerving (knowing that there is a given right answer sometimes makes it easier to think of your answer). This vagueness/nuance is inevitable when thinking about societal/ethical implications of your work. Embrace this uncertainty!
Survey
Each group member will fill in a survey rating their own and their other group members' contribution to the project under the categories of team role, leadership, participation, professionalism and quality of work (on scale of $0-3$ on each). These scores will then be used to divide the team’s points so that individual students’ survey grades reflect how well they contributed to the overall result. The table below explains what the different numerical values for various categories mean.
Category 0 points
(Unsatisfactory)1 points
(Developing)2 points
(Satisfactory)3 points
(Exemplary)Teamwork Does not willingly assume team roles;
Rarely completes assigned workUsually accepts assigned team roles;
Occasionally completes assigned workAccepts assigned team roles;
Mostly completes assigned workAccepts all assigned team roles;
Always completes assigned workLeadership Rarely takes leadership role;
Does not collaborate;
Sometimes willing to assist teammatesOccasionally shows leadership;
Mostly collaborates;
Generally willing to assist teammatesShows an ability to lead when necessary;
Willing to collaborate;
Willing to assist teammatesTakes leadership role;
Is a good collaborator;
Always willing to assist teammatesParticipation Often misses meetings;
Routinely unprepared for meetings;
Rarely participates in meetings and does not share ideasOccasionally misses or does not participate in meetings;
Somewhat prepared for meetings;
Offers unclear or unhelpful ideas in meetingsAttends and participates in most meetings;
Comes prepared to meetings;
Offers useful ideas in meetingsAttends and participates in all meetings;
Comes prepared to meetings;
Clearly expresses well-developed ideas in meetingsProfessionalism Often discourteous and/or openly critical of teammates;
Does not want to listen to any alternate perspectivesNot always considerate or courteous towards teammates;
Usually appreciates teammates' perspectives, but often unwilling to consider themMostly courteous to teammates;
Values teammates' perspectives and often willing to consider themAlways courteous to teammates;
Values teammates' perspectives, knowledge, and experiences, and always willing to consider themQuality Rarely contributes to the coding and reflections components of the project;
Others often required to revise, debug, or fix their workOccasionally contributes to the coding and reflections components of the project;
Others sometimes needed to revise, debug, or fix their workOften contributes to the coding and reflections components of the project;
Others occasionally needed to revise, debug, or fix their workFrequently contributes to the coding and reflections components of the project;
Others rarely needed to revise, debug, or fix their work