Multi-agent systems Week 6 Marko Řeháček & Megi Kejstová rehacek@mail.muni.cz, makej@mail.muni.cz GENERATIVE DESIGN PROGRAMMINGMULTI-AGENT SYSTEMS Cybernetics Rule 90 generating Sierpinski triangle fractal GENERATIVE DESIGN PROGRAMMING → A-LIFE PROGRAM Game of life John Horton Conway, 1970 Most popular cellular automaton. It takes place on an infinite two-dimensional grid in which cells can be alive or dead, and is defined by a set of rules that jointly determine the state of a cell given the state of its neighbours. Following specification of an initial configuration, patterns evolve over time across the grid requiring no further user input. The rules 1. Any live cell with two or three live neighbours survives. 2. Any dead cell with three live neighbours becomes a live cell. 3. All other live cells die in the next generation. Similarly, all other dead cells stay dead. Example: alexandrunst.github.io/Game-of-Life/ Youtube: GoL in GoL Wikipedia GENERATIVE DESIGN PROGRAMMING Multi-agent system environment multiple interacting agents GENERATIVE DESIGN PROGRAMMING In solitude, I wander with a purpose in mind, but in a group, my actions intertwine. I avoid collisions, keep a proper space, and mimic my neighbors at a steady pace. Though I act alone, there's a collective dance, where harmony emerges, a result of chance. What am I, embodying a rule-driven elegance, showing that from chaos can spring emergence?" What am I? GENERATIVE DESIGN PROGRAMMING → Reynolds invented algorithmic steering behaviors for animated characters. These behaviors allowed individual elements to navigate their digital environments in a “lifelike” manner with strategies for fleeing, wandering, arriving, pursuing, evading. Boids is an A-life program simulating the flocking behaviour of birds. A genre of swarm art emerged. A-LIFE PROGRAM MULTI-AGENT SYSTEMS Boids Craig Reynolds, 1986 Coding Adventure: Boids, by Lague https://www.youtube.com/watch?v=bqtqltqcQhw Algorithm explanation Example -> GENERATIVE DESIGN PROGRAMMING → PROJECTION Inside a Flock / Uvnitř Hejna Tomáš Janoušek, 2022 Projection simulates flocking of birds with a spectator inside. Birds fly in groups, they also separate and form new groups. Spectator can scatter them by walking to them. Installation extends boids structures by Craig Reynolds from the year 1986 using multiple layers and interactivity. GENERATIVE DESIGN PROGRAMMING → MULTI-AGENT SYSTEMS MOVIE An Autonomous Agent Choreo Toni Mitjanit, 2016 Attraction-repulsion. https://filmfreeway.com/aaac GENERATIVE DESIGN PROGRAMMING Recap GENERATIVE DESIGN PROGRAMMING Vectors RECAP const v = createVector(x, y, [z]) // v.x returns x coordinate // v.y returns y Many methods available - set() to change x, y without creating new vector - add() to add two vectors, or add scalar - mult() to multiply fields by scalar - array() access as array instead of object - random2D() create random vector … reference page with more methods GENERATIVE DESIGN PROGRAMMING Class vs. Object only class Car { constructor(whose) { this.mileage = 340671; this.owner = whose; } rent() { this.mileage = 121020; } } const obj = new Car(“Peder”); OOP recap RECAP Example -> Example 2 -> let car = { mileage: 340671, owner: “Peder”, array : [ “some”, “text”, “for”, “example” ] } car.owner = “Jano”; car[‘owner’] = “”; GENERATIVE DESIGN PROGRAMMING Autonomous agents GENERATIVE DESIGN PROGRAMMING ❏ has limited ability to perceive environment ❏ processes the information from its environment and calculates an action ❏ has no leader Autonomous agent… AUTONOMOUS AGENTS GENERATIVE DESIGN PROGRAMMING Dumb agent AUTONOMOUS AGENTS 1. write a class representing Agent a. store it’s position (createVector()) b. create draw method, which makes the visual representation of it 2. it does nothing, just sits in center of screen GENERATIVE DESIGN PROGRAMMING Random walk AUTONOMOUS AGENTS Move and in each step, choose direction randomly. Finished code ->Examples from the book Generative Design: Visualize, Program, and Create with JavaScript in p5.js (Benedikt Groß, Hartmut Bohnacker, Julia Laub) �� GENERATIVE DESIGN PROGRAMMING 4am Brno AUTONOMOUS AGENTS 1. implement random walk (https://editor.p5js.org/mrehacek/sketches/BpWZUDqJe) 2. spawn more agents Code: single agent Code: complete GENERATIVE DESIGN PROGRAMMING More intelligent movement AUTONOMOUS AGENTS Examples from the book Generative Design: Visualize, Program, and Create with JavaScript in p5.js (Benedikt Groß, Hartmut Bohnacker, Julia Laub) �� GENERATIVE DESIGN PROGRAMMING Drunk but intelligent agent AUTONOMOUS AGENTS 1. bounce of the edge – implement edge collisions Code: complete GENERATIVE DESIGN PROGRAMMING Let’s try to simulate some apple falling. What are the laws? A force is a vector that causes an object with mass to accelerate. Newton’s first An object at rest stays at rest and an object in motion stays in motion at a constant speed and direction unless acted upon by an unbalanced force. Newton’s second Force equals mass times acceleration. F=M×A Physical simulations AUTONOMOUS AGENTS velocity vector Code: complete acceleration vector GENERATIVE DESIGN PROGRAMMING Gravity AUTONOMOUS AGENTS Make agent fall with gravity and bounce of the canvas edge. Use velocity and acceleration. Force, in our case downward acting gravity, will change acceleration, and acceleration will add speed of the object. Code: complete GENERATIVE DESIGN PROGRAMMING Shapes and noise AUTONOMOUS AGENTS Examples from the book Generative Design: Visualize, Program, and Create with JavaScript in p5.js (Benedikt Groß, Hartmut Bohnacker, Julia Laub) �� GENERATIVE DESIGN PROGRAMMINGAUTONOMOUS AGENTS Examples from the book Generative Design: Visualize, Program, and Create with JavaScript in p5.js (Benedikt Groß, Hartmut Bohnacker, Julia Laub) GENERATIVE DESIGN PROGRAMMINGAUTONOMOUS AGENTS Growth structures ���� Examples from the book Generative Design: Visualize, Program, and Create with JavaScript in p5.js (Benedikt Groß, Hartmut Bohnacker, Julia Laub) GENERATIVE DESIGN PROGRAMMING Pendulums AUTONOMOUS AGENTS Examples from the book Generative Design: Visualize, Program, and Create with JavaScript in p5.js (Benedikt Groß, Hartmut Bohnacker, Julia Laub) �� GENERATIVE DESIGN PROGRAMMING Drawing with mouse AUTONOMOUS AGENTS ��Examples from the book Generative Design: Visualize, Program, and Create with JavaScript in p5.js (Benedikt Groß, Hartmut Bohnacker, Julia Laub) GENERATIVE DESIGN PROGRAMMING Drawing type AUTONOMOUS AGENTS ��Examples from the book Generative Design: Visualize, Program, and Create with JavaScript in p5.js (Benedikt Groß, Hartmut Bohnacker, Julia Laub) GENERATIVE DESIGN PROGRAMMING Cells AUTONOMOUS AGENTS Symmetries Examples from the book Generative Design: Visualize, Program, and Create with JavaScript in p5.js (Benedikt Groß, Hartmut Bohnacker, Julia Laub) ���� GENERATIVE DESIGN PROGRAMMINGAUTONOMOUS AGENTS GENERATIVE DESIGN PROGRAMMING Drawing tablet AUTONOMOUS AGENTS GENERATIVE DESIGN PROGRAMMINGAUTONOMOUS AGENTS GENERATIVE DESIGN PROGRAMMING Animated brush MULTI-AGENT SYSTEMS – EXAMPLES GENERATIVE DESIGN PROGRAMMING → MULTI-AGENT SYSTEMS – EXAMPLES TUTORIAL GENERATIVE DESIGN PROGRAMMING → INTERACTIVE APP MULTI-AGENT SYSTEMS – EXAMPLES Weavesilk Yuri Vishnevsky http://weavesilk.com/ GENERATIVE DESIGN PROGRAMMING → IMAGE MULTI-AGENT SYSTEMS – EXAMPLES Unnamed Hana Tokárová, 2020 GENERATIVE DESIGN PROGRAMMING → IMAGE MULTI-AGENT SYSTEMS – EXAMPLES Dragon brush Juraj Ulbrich, 2020 GENERATIVE DESIGN PROGRAMMING → IMAGE MULTI-AGENT SYSTEMS – EXAMPLES Star brush Tamara Babálová, 2020 GENERATIVE DESIGN PROGRAMMING Animated brush AUTONOMOUS AGENTS 1. write a class representing Agent a. store it’s position (createVector()) b. create draw method, which makes the visual representation of it 2. instantiate several agents on random positions (new Agent(...)) and store them in an array 3. inside the sketch’s draw(), call draw() on each agent, so the agents can draw themselves a. remember, the agents are autonomous (don’t make the sketch’s draw() function the leader) 4. create agents on mouse click (mouseClicked() + mouseX + mouseY) 5. move the agents 6. implement some interesting behavior (inspiration in slides) a. move in random/noise direction b. cellular life – die after being drawn X times c. bounce from the boundaries of the sketch GENERATIVE DESIGN PROGRAMMING Cellular automata MULTI-AGENT SYSTEMS Nature of code chapter GENERATIVE DESIGN PROGRAMMING 1-dimensional cellular automata MULTI-AGENT SYSTEMS 1. You have row of cells, cells have state on and off (1 or 0) 2. Based on the row, you calculate new row using rules. For example, if we look at first 3 cells, and they are all “on”, then turn off the middle cell in new row. 3. Repeat infinitely, usually draw rows below each other to show the progress. GENERATIVE DESIGN PROGRAMMING Rule 30 “They seem to be uncrackable … they show irreducible computation” “Can you prove it will never repeat? We were never able to show that“ “Are there equal number of 0,1 in center column?” Lex Fridman + Stephen Wolfram podcast A Conus textile shell similar in appearance to Rule 30. GENERATIVE DESIGN PROGRAMMING In 2004, Matthew Cook published a proof that Rule 110 with a particular repeating background pattern is Turing complete, i.e., capable of universal computation, which Stephen Wolfram had conjectured in 1985. Recreate it. Rule 110 Finished code GENERATIVE DESIGN PROGRAMMING → IMAGE, A-LIFE PROGRAM Game of image Ján Popeláš, 2020 MULTI-AGENT SYSTEMS – EXAMPLES GENERATIVE DESIGN PROGRAMMING → IMAGE, A-LIFE PROGRAM Crosshatch Automata Kjetil Golid, 2020 Isometric cellular automaton. Four rules makes up a pattern, each rule determining the behaviour of one line direction (horizontal, vertical, descending- and ascending diagonally). https://generated.space/sketch/crosshatch-automata/ MULTI-AGENT SYSTEMS – EXAMPLES GENERATIVE DESIGN PROGRAMMING → IMAGE, PROJECTION MULTI-AGENT SYSTEMS – EXAMPLES Roko’s heart Santiago . Project + Code -> GENERATIVE DESIGN PROGRAMMING → IMAGE Edge of chaos Tim Zarki, 2022 Behance MULTI-AGENT SYSTEMS – EXAMPLES GENERATIVE DESIGN PROGRAMMING → INTERACTIVE INSTALLATION The Emergence and Decay of Computation Alexander Miller, 2019 Receipt printers that hang from their own receipts above a basin of water and slowly print themselves to death over the course of three days. The printers output rows of a cellular automaton — a mathematical simulation that generates emergent patterns from simple rules. Entering the water short circuits the printer, permanently killing it. The output of the cellular automaton simulation is directly responsible for the destruction of the device computing the simulation. SFPC student showcase 2019 MULTI-AGENT SYSTEMS – EXAMPLES GENERATIVE DESIGN PROGRAMMING Flowfields MULTI-AGENT SYSTEMS – EXAMPLES Explanation in Nature of Code, video series GENERATIVE DESIGN PROGRAMMING GENERATIVE DESIGN PROGRAMMING → MULTI-AGENT SYSTEMS – EXAMPLES INTERACTIVE APP Typoflow Marko Řeháček, 2019 Gitlab GENERATIVE DESIGN PROGRAMMING → Tyler Hobbs — Loxodography 0.26 Tyler Hobbs — Loxodography 0.26 GENERATIVE DESIGN PROGRAMMING → Jason Labe - Noise Flow Field Painter MULTI-AGENT SYSTEMS – EXAMPLES GENERATIVE DESIGN PROGRAMMING → MULTI-AGENT SYSTEMS – EXAMPLES Daniel Shiffman GENERATIVE DESIGN PROGRAMMINGMULTI-AGENT SYSTEMS – EXAMPLES Create a grid of Perlin noise values. Move agent in the direction of the values (follow higher ones) or create more complicated movement. Flowfield Example from class GENERATIVE DESIGN PROGRAMMING Other sources GENERATIVE DESIGN PROGRAMMING natureofcode.com /book 1. VECTORS 2. FORCES 3. OSCILLATION 4. PARTICLE SYSTEMS 5. PHYSICS LIBRARIES 6. AUTONOMOUS AGENTS 7. CELLULAR AUTOMATA 8. FRACTALS 9. THE EVOLUTION OF CODE 10. NEURAL NETWORKS GENERATIVE DESIGN PROGRAMMING → System of ordinary differential equations first studied by mathematician and meteorologist Edward Lorenz. https://editor.p5js.org/GenJamGuy/sketches/TUOEwXvty Lorenz attractor https://en.wikipedia.org/wiki/Lorenz_system GENERATIVE DESIGN PROGRAMMING Touch Designer BONUS GENERATIVE DESIGN PROGRAMMING Touch Designer BONUS Node based visual programming language - Real-time visualizations content - Save usage (no program crashing due to errors) - Time efficient, easy to debug GENERATIVE DESIGN PROGRAMMING Touch Designer BONUS Free Non-commercial version (maximum 1280 x 720 px) Touchdesigner – https://derivative.ca/ Beginner course – https://youtu.be/Z_WfldiO6HI?si=TYTaPp99yv3x0nNa Tutorials – https://www.youtube.com/@pppanik007 GENERATIVE DESIGN PROGRAMMING Homework 3: MAS Create artwork using the principles from this week’s class. It can be a simulation of paint brush, a unique cellular automaton, or a dancing choreography of agents. If you incorporate emergent behavior or properties, that’s great accomplishment! Look in the slides for inspiration. The work needs to show skills learnt from last two weeks of classes and be more than was made during live-coding. Technical information regarding the submission and deadline will be in interactive syllabus in IS. Deadline 22.11.2023 (including).