Embedded EthiCSTM @ Harvard Bringing ethical reasoning into the computer science curriculum

We Value Your Feedback! Help us improve by sharing your thoughts in a brief survey. Your input makes a difference—thank you!

Programming Languages (CS 152) – Spring 2022

First time reviewing a module? Click here.

Click  to access marginalia information, such as reflections from the module designer, pedagogical decisions, and additional sources.

Click “Download full module write-up” to download a copy of this module and all marginalia information available.

Module Topic: Designing Usable Programming Languages
Module Author: Eliza Wells

Course Level: Upper Level Undergraduate
AY: 2020-2021

Course Description: “This course is an introduction to the theory, design, and implementation of programming languages. Topics covered in this course include: formal semantics of programming languages (operational, axiomatic, denotational, and translational), type systems, higher-order functions and lambda calculus, laziness, continuations, dynamic types, monads, objects, modules, concurrency, and communication.” (Course description

Semesters Taught: Spring 2018, Spring 2019, Spring 2021, Spring 2022, Spring 2023

    Tags

  • programming languages [CS]
  • justice [phil]
  • egalitarianism [phil]

Module Overview

This module focuses on how easy programming languages are to learn and use. In particular, students are introduced to the idea that programming language usability can be a problem of justice. The module introduces an egalitarian framework to help students see that morally irrelevant factors (e.g. vision impairment or not being a native English speaker) impact whether or not some populations are able to access the goods provided by computer science. The module discusses different elements of programming languages, such as documentation and intuitive design, that can impact programming language usability and asks students to think through ways that they can design programming languages so that morally irrelevant factors don’t impact usability.

    Connection to Course Material

The material in this course is very technical and mathematical. Rather than engage in detail with concepts learned in the course, this module’s approach is to zoom out from course material and ask students to think about programming languages in their social context.

Students in this course learn about the formal foundations of programming languages. They are taught about some values that good programming languages realize, such as memory-safety, and ways that they can both test and design for those values. This module considers another value that a good programming language should realize: usability. It encourages students to think about the people who use programming languages, and which people are able to sufficiently take advantage of the technically important features students learn about in the course.

Goals

Module Goals

  1. Familiarize students with the philosophical concept of egalitarianism as a way of thinking about justice.
  2. Explore how programming language usability is a justice issue.
  3. Practice thinking through different ways in which students can design programming languages for usability.

    Key Philosophical Questions

This module argues that the answer to question #1 is yes. By thinking through the first three questions, students are prepared to see that the answer to the final question is that computer scientists have a responsibility to ensure where possible that morally irrelevant traits don’t impact usability.

  1. Is programming language usability a justice issue?
  2. What goods do individuals have access to through computer science?
  3. What morally irrelevant traits impact individuals’ access to those goods?
  4. What responsibility do computer scientists have to make programming languages usable?

Materials

    Key Philosophical Concepts

The module focuses on how morally irrelevant traits can impact whether or not some people are able to use different programming languages. Egalitarianism (understood as the claim that, because all people have equal moral standing, different treatment on the basis of morally irrelevant traits is unjust) helps students to see why this is morally problematic.

  • Justice
  • Egalitarianism
  • Morally irrelevant traits

    Assigned Readings

This article introduces the basic claims of egalitarianism and discusses different kinds of goods that should be distributed equally under an egalitarian framework – welfare, resources, capabilities, etc. As well as introducing them to the key philosophical topic, this reading prepared students to think about a variety of goods that might be at stake in programming language usability.

Implementation

Class Agenda

  1. Overview.
  2. Class discussion of the various goods to which being a computer scientist provides access.
  3. Egalitarianism as a way of thinking about how those goods should be distributed.
  4. Programming language usability as one case where the goods of computer science are distributed unequally.
  5. Different ways in which programming languages can be more or less usable.
  6. Thinking through usability using case studies of blind and low-vision programmers and non-native English speakers.

    Sample Class Activity

This activity is an opportunity for students to apply the concepts they’ve learned to the particular question of programming language usability. When encouraged, students were able to come up with a long list of factors that might limit access to these goods and discuss the nuances of whether those factors (e.g. motivation to learn programming) should be considered morally relevant.

In small groups, students are asked to discuss:

  1. What goods are at stake?
  2. What factors limit access to those goods?
  3. Are those factors morally relevant?

They are then presented with a case study of non-native English speakers who have difficulty using programming languages and asked:

  1. What can we do about it?

    Module Assignment

This assignment asks students to take the abstract lessons of the module and apply them concretely to a language they have experience with. In their responses, students were able to bring out how a variety of technical features impact usability. Few of them, however, engaged in much detail with an egalitarian perspective on which populations were less able to use the programming language they discussed. A future version of this question could highlight that dimension more explicitly.

Students are asked to respond to the following question on a class thread: Choose a programming language with which you are familiar. Which features of this language make it usable? For whom? Is there a way in which it could be made more usable (e.g. better documentation, more intuitive design, etc.)?

Lessons Learned

  • Students were engaged with the content of the module and very willing to discuss how big-picture social factors (e.g. access to education, socioeconomic status, values in the community in which one is raised) impacted usability. In the course of the discussion, it became clear that designing programming languages to be more usable is a very small change in a complex system of injustice. Future versions of this module could do more to situate programming language usability within that bigger system.
  • Future versions of this module could do more to highlight the different justice issues brought out by a) not being able to use any programming language versus b) not being able to use a particular programming language.
  • One of the difficult questions of egalitarianism is “What counts as a morally irrelevant trait?” Students were able to bring out interesting edge cases, like motivation to learn a programming language, that may or may not be justice issues. Future modules could lean into this complexity.
  • This module did not have time to discuss the question of how computer scientists can concretely realize their responsibility to make programming languages usable, and what burdens they ought to take on in order to achieve that. Students were interested in this question.

Except where otherwise noted, content on this site is licensed under a Creative Commons Attribution 4.0 International License.

Embedded EthiCS is a trademark of President and Fellows of Harvard College | Contact us