Back to Courses
AI019 Professional

Programming Elixir

A comprehensive guide to functional and concurrent programming using Elixir. It covers the transition from object-oriented to functional thinking, pattern matching, immutability, the actor model for concurrency, and building robust distributed systems with OTP.

4.8
30.0h
981 students
0 likes
Artificial Intelligence
Start Learning

Lessons

Lesson

This lesson introduces Elixir as a functional language focused on data transformation, emphasizing the importance of immutability and the use of the pipe operator for clean, predictable code. Students will also learn how Elixir’s actor-based concurrency model uses isolated processes and message passing to ensure thread safety and system scalability.

This lesson introduces the functional paradigm of Elixir, focusing on the core concept of data immutability and the use of pattern matching over variable mutation. Students will learn how to perform data transformations to create new values rather than modifying existing ones, ensuring predictable and thread-safe code.

This lesson explores foundational functional programming in Elixir, focusing on anonymous and named functions, module encapsulation, and the use of the pipe operator for data transformation. Students will also learn to leverage pattern matching and the `with` expression to handle complex, multi-step logic safely and effectively.

AI019: Recursive Lists and Data Structures (Lesson 4) explores the recursive nature of linked lists in Elixir, focusing on head-tail decomposition and the implementation of custom recursive functions. Students will learn to identify base cases, utilize the cons operator, and apply recursive patterns to perform efficient list operations.

This lesson explores the differences between greedy processing with the Enum module and lazy processing with the Stream module in Elixir. Students will learn to implement the Enumerable protocol and apply these concepts to perform memory-efficient data transformations and advanced string processing.

This lesson explores advanced Elixir control flow, focusing on pattern matching with case expressions, guard clauses, and the use of the with construct for error handling. Students will also learn to manage project structures using Mix and improve code quality through professional tooling like Credo and Dialyzer.

This lesson explores how to maintain persistent state in Elixir using recursive functions and Tail-Call Optimization (TCO) to keep processes alive. Students will learn to manage process lifecycles, handle message passing, and implement deterministic communication patterns in concurrent systems.

This lesson explores the fundamentals of the Open Telecom Platform (OTP) in Elixir, focusing on how behaviors, supervision trees, and I/O messaging enable the creation of fault-tolerant, distributed applications. Students will learn to implement GenServers and leverage the Error Kernel philosophy to build robust systems that effectively manage process lifecycles and inter-node communication.

This lesson explores advanced OTP architectures and the Five-Question Framework to achieve high-reliability state management in Elixir. Students will learn to design robust supervision trees and distributed systems by systematically defining environment constraints, focal points, and fault-tolerance strategies.

This lesson explores Elixir’s metaprogramming capabilities, focusing on how the language's homoiconic nature allows source code to be treated as data via the Abstract Syntax Tree (AST). Students will learn to design extensible software using protocols and macros while evaluating how static analysis tools like Dialyzer provide type safety without sacrificing dynamic flexibility.

Course Overview

📚 Content Summary

A comprehensive guide to functional and concurrent programming using Elixir. It covers the transition from object-oriented to functional thinking, pattern matching, immutability, the actor model for concurrency, and building robust distributed systems with OTP.

Master the art of building resilient, concurrent systems through the beauty of functional programming.

Author: Dave Thomas

Acknowledgments: José Valim, Corey Haines, Bruce Tate, Jessica Kerr, Anthony Eden, Chad Fowler, Kim Shrier, Candace Cunningham, and Potomac Indexing.

🎯 Learning Objectives

  1. Contrast the data transformation model of Elixir with conventional state-based programming.
  2. Configure the interactive Elixir shell (IEx) and execute Elixir code via scripts and compilation.
  3. Apply the match operator (=), pin operator (^), and wildcard (_) to destructure and validate data.
  4. Explain the theoretical and practical implications of immutability on performance and memory management.
  5. Identify and utilize Elixir's built-in types, including Value, System, and Collection types.
  6. Apply variable scoping rules and the with expression to manage complex data transformations.
  7. Create and invoke anonymous functions using both standard and capture (&) notation.
  8. Implement named functions within modules using pattern matching and recursion to handle complex logic.
  9. Apply guard clauses and default parameters to control function execution flow.
  10. Deconstruct and Construct Lists: Use head/tail pattern matching to navigate and build recursive list structures.

Lessons