GitPedia

Effects

A brief exploration of the various approaches to modeling side effects in a purely functional programming language.

From stepchowfun·Updated August 30, 2025·View on GitHub·
·Archived

A brief exploration of the various approaches to modeling side effects in a purely functional programming language. The project is written primarily in Haskell, distributed under the Other license, first published in 2018. Key topics include: computational-effects, functional-programming, haskell.

Effects

A brief exploration of the various approaches to modeling side effects in a purely functional programming language.

Build status

The challenge

Write a program that initializes an accumulator and random seed both with 0 and then runs the following procedure 10 times:

  • Log the value of the accumulator.
  • Pick an integer uniformly randomly from the half-open interval [0, 10).
  • Mutate the accumulator by adding the random integer to it.

Thus, 3 computational effects are exhibited: logging, randomness, and mutable state.

Techniques demonstrated

This repository contains 4 implementations of the program described above, each demonstrating a specific technique:

Instructions

Make sure you have Toast installed. Then you can run toast run to build and run the demo.

Contributors

Showing top 3 contributors by commit count.

View all contributors on GitHub →

This article is auto-generated from stepchowfun/effects via the GitHub API.Last fetched: 6/24/2026