Functional Python Programming in Introductory Computer Science Courses
By: Rajshekhar Sunderraman
Potential Business Impact:
Teaches coding skills by making programs safer.
The functional programming paradigm has a long and storied history, with its beginnings in the Lambda Calculus. In recent decades, pure functional languages such as Haskell have been shown to be highly effective in producing robust software due to immutable data structures, among other functional features. The advantages of programming with immutable data structures can also be had in non-functional languages such as Python. Over the years, non-functional languages have introduced immutable data structures as well as comprehension and lambda expressions, and it is possible to program in a purely functional style in them. In this paper, we present a ``best practice'' idea in introductory programming classes that forces students to learn and complete programming assignments in a purely functional subset of Python. By doing so, the student can learn functional ideas such as immutability, pure functions with no side effects, and stateless programming. We define a functional subset of Python and illustrate the best practice using small examples. We strongly feel that students in computing need familiarity with pure functional programming and argue that this can be taught in introductory programming courses that use Python.
Similar Papers
Teaching Introductory Functional Programming Using Haskelite
Programming Languages
Teaches computer code by showing each step.
Effect-driven interpretation: Functors for natural language composition
Computation and Language
Makes computer programs understand language like humans.
Functional vs. Object-Oriented: Comparing How Programming Paradigms Affect the Architectural Characteristics of Systems
Software Engineering
Helps choose best way to build computer programs.