Introducing Facet: a procedural brand image system built with agentic coding

2026-03-16 • Scott Boyle

How AI-assisted workflows helped turn the Measured visual system into a procedural image tool, without lowering UI standards or output quality.


The context

This post relies heavily on two core concepts, agentic engineering and flexible visual systems. So let’s define those.

Agentic engineering

I’ll leave this to Simon Willison, who draws a useful distinction between agentic engineering and vibe coding:

I think of vibe coding using its original definition of coding where you pay no attention to the code at all … Agentic Engineering represents the other end of the scale: professional software engineers using coding agents to improve and accelerate their work by amplifying their existing expertise.

Writing about agentic engineering patterns

We’ve been using agentic engineering approaches heavily over the past year in both personal and professional contexts.

Flexible visual systems

Flexible Visual Systems by Martin Lorenz outlines an approach to visual brand identity that goes beyond the static logo. It’s a method for defining a visual language that can produce many consistent expressions.

A spread from the book Flexible Visual Systems by Martin Lorenz. The pages show orange and green geometric icons, demonstrating how a single seed shape can be manipulated to create a sophisticated visual language.

The Measured visual brand system was designed using a process inspired by this approach (in collaboration with designer James Cross).

Key to a flexible system is shape as a core component of the grammar. In the Measured system, that core shape is The Corner (plus related derived components).

Diagram of The Corner brand asset, showing the thick blue L-curve and its proportional sub-components, which serve as the primary geometric grammar for the visual system.

The problem

Measured blog posts use abstract/geometric images (banner, OG, other social) that express the visual system identity and feel recognisably Measured.

We had a small set of compositions from the original identity work to use for these, but we had effectively run out.

A dark-themed blog post layout with a header image composed of layered, blue curves and right angle.

The idea

We decided to build a tool to generate new images for Measured posts and campaigns, using constraints from the Measured visual system.

The inspiration

The creative direction came from Processing-style generative art: not AI image generation, but procedural systems.

I’ve always enjoyed this space, for example, the work of Mark Webster.

Three panels of abstract generative art featuring glitch aesthetics, distorted textures, warped monochrome shapes, and distorted pixelated orange typography.

But I’d never gone deep with Processing before, and the learning curve looked steep.

The question

So could agentic coding help bridge that gap?

Despite regular use of agentic engineering workflows, I’d yet to lean into vibe coding for anything serious. At Measured, we’re accountable for the production code we ship to clients, so every line is reviewed.

But this project felt like a good time to give “letting go” a try.

The experiment

The concept was bounded by three principles:

  • Let the agent write all the p5.js generation code, with no review (vibed).
  • Use agentic assistance plus in-browser review for UI/UX iteration.
  • Keep strong constraints from the Measured visual brand system.

The process

I started by writing a planning doc (with agent assistance) that defined the goal, palette rules, component SVG paths and art-direction constraints.

Then from a one-shot prompt, I immediately got a functioning baseline: canvas, generate action and download action. This was pretty surprising for a few minutes’ work.

Initial Facet prototype screenshot

What followed was iterative: propose a feature, implement it, review it in-browser; accept, tweak or reject it. Describing outcomes in plain language worked really well for this kind of build, as most decisions were visual or behavioural.

Collaboration with the agent (Codex 5.3 in VS Code in this case) was substantive. Beyond defining features, I also asked for tradeoffs between approaches, new feature suggestions, code performance reviews and plan iteration. What I got back was generally insightful input that helped inform the direction I chose.

I also learnt a lot about p5.js and Processing. Whilst still being very much a novice, I was able to generate visually coherent and usable results.

The UI quality bar

As a design engineer, I set a high bar for brand consistency, interaction quality and accessibility. The generated UI was useful early on, but not at a standard we would want to publish as a Measured product. So I did get more hands-on with the UI and UX, requesting specific HTML patterns for accessibility and hand-coding CSS.

Accessibility in particular was a point of failure: the agent produced a lot of plausible-looking aria slop that, on inspection, turned out to be anti-patterns rather than best practice.

The combination that worked:

  • Rapid agent iteration (design-in-browser speed).
  • Human refinement for interaction detail, accessibility, and brand fit.

Results

Here’s the finished app: Facet.

Screenshot of the Facet interface, with adjustment sliders for things like Amount, Size, and Opacity, alongside a preview canvas displaying a procedurally generated blue geometric pattern.

Here are some example images created with Facet’s Randomise and Shuffle functions using brand primary colours.

A collage of images in Measured blue. Each shows a different procedural arrangement of "The Corner", ranging from a single bold graphic to complex, layered patterns.

Here are some with extended palettes.

A collage of images using an extended colour palette, featuring layered geometric shapes.

Takeaways

For this project, agentic workflows weren’t just about a quick result. They lowered the barrier to building a custom creative tool that would otherwise have been completely blocked by library and domain learning curves. The agent also proved an educational and collaborative creative partner.

But what really made this work for us was applying our own constraints, iteration and judgement.

Try Facet and let me know what you think.

How can we help?