118 Decks - Latest First - Chse one - invert order

 1 Imperative Bowling Kata - 20 Years On - Delegating Menial Tasks to Github Copilot Chat - using Scala in IntelliJ IDEA
slide 1
 2 Imperative Bowling Kata - 20 Years On - Delegating Menial Tasks to AI Coding Tool 'Claude Code'
slide 1
 3 AI Concepts - MCP Neurons
slide 1
 4 Combinatorial Interview Problems with Backtracking Solutions - from Procedural to Functional Programming - Part 2
slide 1
 5 Combinatorial Interview Problems with Backtracking Solutions - from Procedural to Functional Programming - Part 1
slide 1
 6 Test Doubles - Terminology, Definitions and Illustrations - with Examples - Part 1
slide 1
 7 ApplicativeError functions handling and recovering from errors: A mnemonic to recall their signatures from their names
slide 1
 8 Folding Cheat Sheet #9 - List Unfolding - 'unfold' as the Computational Dual of 'fold', and how 'unfold' relates to 'iterate'
slide 1
 9 List Unfolding - 'unfold' as the Computational Dual of 'fold', and how 'unfold' relates to 'iterate'
slide 1
 10 Drawing Heighway’s Dragon - Part 4 - Interactive and Animated Dragon Creation
slide 1
 11 The Nature of Complexity in John Ousterhout’s Philosophy of Software Design
slide 1
 12 Drawing Heighway’s Dragon - Part 3 - Simplification Through Separation of Concerns - Rotation Without Matrix Multiplication
slide 1
 13 Drawing Heighway’s Dragon - Part 2 - Recursive Function Simplification - From 2^n Recursive Invocations To n Tail-Recursive Invocations Exploiting Self-Similarity
slide 1
 14 Drawing Heighway’s Dragon - Part 1 - Recursive Function Rewrite - From Imperative Style in Pascal 64 To Functional Style in Scala 3
slide 1
 15 Fibonacci Function Gallery - Part 2
slide 1
 16 Fibonacci Function Gallery - Part 1
slide 1
 17 The Debt Metaphor - Ward Cunningham in his 2009 YouTube video
slide 1
 18 From Subtype Polymorphism To Typeclass-based Ad hoc Polymorphism - An Example
slide 1
 19 Folding Cheat Sheet #8 - Folding with monoids
slide 1
 20 Function Applicative for Great Good of Leap Year Function
slide 1
 21 Folding Cheat Sheet #7 - The three duality theorems of fold
slide 1
 22 Folding Cheat Sheet #6 - Left and right folds and tail recursion
slide 1
 23 Folding Cheat Sheet #5 - Folding a list right and left using Cons and Nil results in the identity and reverse functions
slide 1
 24 Hand Rolled Applicative User Validation Code Kata
slide 1
 25 A Sighting of filterA in Typelevel Rite of Passage
slide 1
 26 Direct Style Effect Systems - The Print[A] Example - A Comprehension Aid
slide 1
 27 Folding Cheat Sheet #4 - For functions that can be defined both as a right fold and as a left fold, one may be more efficient than the other
slide 1
 28 Folding Cheat Sheet #3 - The universal property of fold
slide 1
 29 Folding Cheat Sheet #2 - Programmatic and mathematical definitions of right fold and left fold
slide 1
 30 Folding Cheat Sheet #1 - Folding over recursively defined data structures for natural numbers and lists
slide 1
 31 Folding Cheat Sheet Series Titles
slide 1
 32 Scala Left Fold Parallelisation - Three Approaches
slide 1
 33 Tagless Final Encoding - Algebras and Interpreters and also Programs
slide 1
 34 Fusing Transformations of Strict Scala Collections with Views
slide 1
 35 A sighting of traverse_ in Practical FP in Scala
slide 1
 36 A sighting of traverseFilter and foldMap in Practical FP in Scala
slide 1
 37 A sighting of sequence function in Practical FP in Scala
slide 1
 38 N-Queens Combinatorial Puzzle meets Cats
slide 1
 39 Kleisli composition, flatMap, join, map, unit - implementation and interrelation - V2 updated for Scala 3
slide 1
 40 The aggregate function - from sequential and parallel folds to parallel aggregation
slide 1
 41 Nat, List and Option Monoids - From scratch - Combining and Folding - An example
slide 1
 42 The Sieve of Eratosthenes - Part 2 - Genuine versus Unfaithful Sieve
slide 1
 43 Sum and Product Types - The Fruit Salad & Fruit Snack Example
slide 1
 44 Algebraic Data Types for Data Oriented Programming - From Haskell and Scala to Java
slide 1
 45 The Sieve of Eratosthenes - Part 1
slide 1
 46 The Uniform Access Principle
slide 1
 47 Computer Graphics in Java and Scala - Part 1b
slide 1
 48 The Expression Problem Part 2
slide 1
 49 Computer Graphics in Java and Scala - Part 1
slide 1
 50 The Expression Problem Part 1
slide 1
 51 Side by Side - Scala and Java Adaptations of Martin Fowler’s Javascript Refactoring Example
slide 1
 52 Refactoring: A First Example - Martin Fowler’s First Example of Refactoring, Adapted to Java
slide 1
 53 Refactoring: A First Example - Martin Fowler’s First Example of Refactoring, Adapted to Scala
slide 1
 54 ‘go-to’ general-purpose sequential collections - from Java To Scala
slide 1
 55 The Functional Programming Triad of map, filter and fold
slide 1
 56 Functional Core and Imperative Shell - Game of Life Example - Haskell and Scala
slide 1
 57 N-Queens Combinatorial Problem - Polyglot FP for Fun and Profit – Haskell and Scala - Part 4
slide 1
 58 Quicksort - a whistle-stop tour of the algorithm in five languages and four paradigms
slide 1
 59 N-Queens Combinatorial Problem - Polyglot FP for Fun and Profit – Haskell and Scala - Part 3
slide 1
 60 Left and Right Folds - Comparison of a mathematical definition and a programmatic one
slide 1
 61 N-Queens Combinatorial Problem - Polyglot FP for Fun and Profit – Haskell and Scala - Part 2
slide 1
 62 N-Queens Combinatorial Problem - Polyglot FP for Fun and Profit – Haskell and Scala - Part 1
slide 1
 63 Sierpinski Triangle - Polyglot FP for Fun and Profit - Haskell and Scala
slide 1
 64 Function Applicative for Great Good of Palindrome Checker Function
slide 1
 65 Scala 3 enum for a terser Option Monad Algebraic Data Type
slide 1
 66 Folding Unfolded - Part 5
slide 1
 67 The Functional Programming Triad of Folding, Scanning and Iteration - A first example in Scala and Haskell
slide 1
 68 Folding Unfolded - Part 4
slide 1
 69 Folding Unfolded - Part 3
slide 1
 70 Folding Unfolded - Part 2
slide 1
 71 Folding Unfolded - Part 1
slide 1
 72 Game of Life - Polyglot FP - Haskell and Scala - Part 3
slide 1
 73 Game of Life - Polyglot FP - Haskell and Scala - Part 2
slide 1
 74 Game of Life - Polyglot FP - Haskell and Scala - Part 1
slide 1
 75 Scala 3 by Example - Algebraic Data Types for Domain Driven Design - Part 2
slide 1
 76 From Scala Monadic Effects to Unison Algebraic Effects
slide 1
 77 Monad Fact #6
slide 1
 78 Monad Fact #5
slide 1
 79 Monad Fact #4
slide 1
 80 Monad Fact #3
slide 1
 81 Monad Fact #2
slide 1
 82 Monad Fact #1
slide 1
 83 The Monad Fact Series
slide 1
 84 Scala 3 by Example - Algebraic Data Types for Domain Driven Design - Part 1
slide 1
 85 State Monad
slide 1
 86 Applicative Functor - Part 3
slide 1
 87 Applicative Functor - Part 2
slide 1
 88 Functional Effects - Part 2
slide 1
 89 Functional Effects - Part 1
slide 1
 90 Symmetry in the interrelation of flatMap/foldMap/traverse and flatten/fold/sequence
slide 1
 91 Ad hoc Polymorphism using Type Classes and Cats
slide 1
 92 Year when lambda functions were introduced in various languages
slide 1
 93 Function Composition - forward composition versus backward composition
slide 1
 94 Non-strict functions, bottom, and Scala by-name parameters
slide 1
 95 Addendum to `Monads do not Compose`
slide 1
 96 Monad Transformers - Part 1
slide 1
 97 Monads do not Compose
slide 1
 98 Functor Composition
slide 1
 99 Sequence and Traverse - Part 3
slide 1
 100 Sequence and Traverse - Part 2
slide 1
 101 Monoids - Part 2 - With examples using Scalaz and Cats
slide 1
 102 Monoids - Part 1 - With examples using Scalaz and Cats
slide 1
 103 Definitions of Functional Programming
slide 1
 104 Sequence and Traverse - Part 1
slide 1
 105 Applicative Functor - Part 1
slide 1
 106 Writer Monad for logging execution of functions
slide 1
 107 Kleisli Composition
slide 1
 108 Monad Laws Must Be Checked
slide 1
 109 Point-free or Die - Tacit Programming in Haskell
slide 1
 110 Monad as Functor with pair of Natural Transformations
slide 1
 111 Natural Transformations
slide 1
 112 Functor Laws
slide 1
 113 Compositionality and Category Theory
slide 1
 114 Arrive at monads by going from composition of pure functions to composition of effectful functions
slide 1
 115 De Morgan's Laws are Monoid Homomorphisms
slide 1
 116 Lambda Expressions and Java 8 - Lambda Calculus, Lambda Expressions, Syntactic Sugar, First Class Functions
slide 1
 117 The Open-Closed Principle - Part 2 - The Contemporary Version - An Introduction
slide 1
 118 The Open-Closed Principle - Part 1 - The Original Version
slide 1