This document discusses using functional programming concepts like comonads to design and implement cellular automata in C++. It describes a 1D, 3-state cellular automaton as a proof of concept. It then discusses extending the approach to 2D cellular automata by using higher-order functions. Benchmark results show the parallel implementation of Conway's Game of Life outperforms the sequential version.