A Sierpinski Triangle is a famous mathematical fractal — a shape made by repeating a pattern inside itself forever.
Start with a triangle ➜ remove the triangle in the middle ➜ repeat the removal process on every remaining triangle forever.
It creates a beautiful, self-similar pattern:
▲
▲ ▲
▲ ▲
▲ ▲ ▲ ▲ | Method | How it works | Pros |
|---|---|---|
| Recursive Draw | Keep dividing triangle into smaller triangles | Clean math, simple to understand |
| Chaos Game | Plot points randomly that converge to fractal | Fast, visually surprising |
<canvas id="canvas" width="600" height="500"></canvas>
<script>
const canvas = document.getElementById("canvas");
const ctx = canvas.getContext("2d");
function drawTriangle(x1, y1, x2, y2, x3, y3) {
ctx.beginPath();
ctx.moveTo(x1, y1);
ctx.lineTo(x2, y2);
ctx.lineTo(x3, y3);
ctx.closePath();
ctx.fill();
}
function sierpinski(x1, y1, x2, y2, x3, y3, depth) {
if (depth === 0) {
drawTriangle(x1, y1, x2, y2, x3, y3);
return;
}
let ax = (x1 + x2) / 2;
let ay = (y1 + y2) / 2;
let bx = (x2 + x3) / 2;
let by = (y2 + y3) / 2;
let cx = (x3 + x1) / 2;
let cy = (y3 + y1) / 2;
sierpinski(x1, y1, ax, ay, cx, cy, depth - 1);
sierpinski(ax, ay, x2, y2, bx, by, depth - 1);
sierpinski(cx, cy, bx, by, x3, y3, depth - 1);
}
// Starter triangle
ctx.fillStyle = "black";
sierpinski(300, 20, 50, 480, 550, 480, 6);
</script>
Try changing the last number (6) → recursion depth
Higher depth = more detail but slower.
const c = document.getElementById("canvas");
const ctx = c.getContext("2d");
const vertices = [
{x:300, y:20},
{x:50, y:480},
{x:550, y:480}
];
let x = 300, y = 200;
function chaosGame() {
for (let i = 0; i < 5000; i++) {
const v = vertices[Math.floor(Math.random()*3)];
x = (x + v.x) / 2;
y = (y + v.y) / 2;
ctx.fillRect(x, y, 1, 1);
}
}
setInterval(chaosGame, 10);
| Concept | Meaning |
|---|---|
| Fractal | Infinite repeating shape |
| Self-similar | Parts look like whole |
| Sierpinski triangle | Subdivide triangle forever |
| JS implementation | Recursion or Chaos Game |
Latest tech news and coding tips.
Every application that stores and manages data relies on a set of basic operations known…
PHP remains one of the most widely used server-side programming languages, powering platforms such as…
Danfo.js is an open-source JavaScript library designed for data manipulation, analysis, and machine learning. It provides…
JavaScript's async and await keywords revolutionized asynchronous programming by making asynchronous code look and behave more like synchronous code.…
Pretty Good Privacy (PGP) is one of the most widely used encryption systems for securing emails,…
Database migration is one of the most challenging tasks in software engineering. While both PostgreSQL…