Map
%3 Content creation workflow--Daily open-source software guide Content creation workflow--Decentralisation Daily open-source software guide--Decentralisation Daily open-source software guide--Software alternatives Decentralisation--Bookmarks Decentralisation--Registry-based search engine MacBook Air M4 Adventures--NixOS MacBook Air M4 Adventures--ReqSnake NixOS--System configuration NixOS--Software alternatives ReqSnake--About ReqSnake--Scratchpad Bookmarks--Registry-based search engine Bookmarks--Website experience Registry-based search engine--Website experience Registry-based search engine--Storybook Website experience--Decentralisation Website experience--2024's Devlog Audio & DSP--Making music on Linux Audio & DSP--GPU Synth Making music on Linux--Custom synth Making music on Linux--Luthier GPU Synth--Custom synth GPU Synth--Sonification Custom synth--Audio & DSP Custom synth--Custom sequencer Custom sequencer--Making music on Linux Custom sequencer--Rust 2024's Devlog--Contact 2024's Devlog--2022's Devlog Contact--Content creation workflow Contact--2025's Devlog 2022's Devlog--Contact 2022's Devlog--The Waiting room 2025's Devlog--2022's Devlog 2025's Devlog--2025's Devlog 2025's Devlog--About 2025's Devlog--2026's Devlog About--Contact About--Scratchpad Piano--Sounds & Melodies Piano--Music Transcribing Sounds & Melodies--Making music on Linux Sounds & Melodies--Custom sequencer Music Transcribing--Sounds & Melodies Music Transcribing--Rust Rust--Making music on Linux Rust--Sounds & Melodies Flying Shooting Game--2025's Devlog Flying Shooting Game--Scratchpad Scratchpad--2025's Devlog Scratchpad--2025's Devlog Colour scheme--System configuration Colour scheme--Software alternatives System configuration--MacBook Air M4 Adventures System configuration--Software alternatives Software alternatives--Content creation workflow Software alternatives--MacBook Air M4 Adventures Sonification--Audio & DSP Sonification--Luthier Excellent Words--Cosmic Horror Excellent Words--Movies/shows Cosmic Horror--How to think Cosmic Horror--Listening Movies/shows--Cosmic Horror Movies/shows--2023's Devlog Model-Based Systems Engineering--MacBook Air M4 Adventures Model-Based Systems Engineering--ReqSnake Exocortex--Bookmarks Exocortex--Website experience Travel--2022's Devlog Travel--The word *Bączek* The word *Bączek*--Reading The word *Bączek*--The Waiting room Caddy--Daily open-source software guide Caddy--Decentralisation The Ławka Initiative--The word *Bączek* The Ławka Initiative--Paintings Paintings--Travel Paintings--The word *Bączek* How to think--Movies/shows How to think--Reading Reading--Excellent Words Reading--Movies/shows 2023's Devlog--2025's Devlog 2023's Devlog--The Waiting room The Waiting room--2025's Devlog The Waiting room--Travel Luthier--Audio & DSP Luthier--GPU Synth 2026's Devlog--Cosmic Horror 2026's Devlog--Listening Listening--Piano Listening--Excellent Words Storybook--Website experience Storybook--Map Map--Website experience Map--Exocortex Content creation workflow Content creation workflow Daily open-source software guide Daily open- source software guide Decentralisation Decentralisation MacBook Air M4 Adventures MacBook Air M4 Adventures NixOS NixOS ReqSnake ReqSnake Bookmarks Bookmarks Registry-based search engine Registry-based search engine Website experience Website experience Audio & DSP Audio & DSP Making music on Linux Making music on Linux GPU Synth GPU Synth Custom synth Custom synth Custom sequencer Custom sequencer 2024's Devlog 2024's Devlog Contact Contact 2022's Devlog 2022's Devlog 2025's Devlog 2025's Devlog About About Piano Piano Sounds & Melodies Sounds & Melodies Music Transcribing Music Transcribing Rust Rust Flying Shooting Game Flying Shooting Game Scratchpad Scratchpad Colour scheme Colour scheme System configuration System configuration Software alternatives Software alternatives Sonification Sonification Excellent Words Excellent Words Cosmic Horror Cosmic Horror Movies/shows Movies/shows Model-Based Systems Engineering Model-Based Systems Engineering ! Exocortex Exocortex Travel Travel The word *Bączek* The word *Bączek* Caddy Caddy The Ławka Initiative The Ławka Initiative Paintings Paintings How to think How to think Reading Reading 2023's Devlog 2023's Devlog The Waiting room The Waiting room Luthier Luthier 2026's Devlog 2026's Devlog ! Listening Listening Storybook Storybook Map Map
You can click on each node, they are links!

This is an automatically generated graph containing all pages on my website, along with the connections calculated using sentence embeddings. If you're interested, you can read the source code.

How is this thing generated?

Explained non-technically

  1. Using an AI-esque tool, I'm generating a mathematical representation of what each page on my site contains, in terms of contents
  2. I'm laying out each page on a graph, so that it is placed close to pages with similar contents and far away from pages with different contents. E.x. programming-related stuff will be grouped together, far away from something travel-related.
  3. I'm drawing links between pages which are the closest. This also generates the "related posts" section at the bottom of each page. The drawn links only serve aesthetic purposes.
  4. Posts are colored depending on their relatedness to 3 topics:
    • More red: art-related
    • More green: computers-related
    • More blue: music-related
    • I'm working on better coloring algorithms based on various gradients

The gory technical details

  1. All of the posts are fed through an embeddings generator, I'm using the Sentence Transformers Python library.
  2. The embeddings are passed to UMAP, a dimensionality reduction algorithm, which takes in multi-dimensional embeddings and projects it down to a 2D representation, which can be drawn as a graph. The projection is done so that the high-level "structure" of the data is preserved (at least that's what the UMAP paper states, I'm not data scientist to argue with the experts).
  3. I'm connecting each post with its top 2 nearest posts (using more clutters up the map).
  4. Coloring is done via calculating cosine similarity between the post content embeddings and embeddings of simple tag-based sentences, such as "music, melodies" or "art, beauty". Currently the gradient is dead-simple, similarity directly affects the R/G/B channel.
  5. graphviz renders the graphs and outputs them as SVGs.

A much better description of a similiar idea on Simon Willison's blog.

Future plans

  1. Make this thing look more "map-alike", whatever that might mean.
  2. Experiment with text clusterisation & dimensionality reduction algorithms, such as:
    • tSNE
    • K-means clustering
    • UMAP
    • Latent Dirichlet allocation
    • DBSCAN
  3. Add #tags. Automatically assign posts to categories with cosine distances.
  4. Introduce color-coding and other visual markers, allowing viewers to make sense of the data based on different metrics:
    • Post tags
    • Links to/from other posts
    • Links outside (to the netsphere)
    • Other connections generated by NLP
  5. Check out KagiSearch/vectordb
  6. Color gradients with Python
  7. Circos