PabloNet

The debate about whether internet-fitted AIs can be creative always seemed besides the point to me. Making art is hard. It’s unfortunate that art selects so strongly for skill. Can we decorrelate the two? It seems so. Cheap interpolative* creativity used by 8 billion non-artists surely surfaces new views of the world.

For these reasons and since I have very little skill I’ve been very excited about the various AI-driven art forms popping up. A couple of months ago I started playing with real-time diffusion of my webcam feed using StreamDiffusion. Specifically, with the intent of generating pretty visuals and hoping to elicit new/interesting feelings. Although it’s very fun, the laptop form-factor breaks the illusion. It feels all temporary and geeky. So, I recently built an LCD frame that can be hanged to a wall with minimal illusion breakers. What I really like about this setup is that making it a proper object opens up new channels of interaction. It’s no longer just a screen, it has permanence. You can leave it there, come back to it at a different time, in a different mood, with different lighting, objects, friends, etc.

Face
Infrared light in the dark
Objects
Friends

Plus, it looks pretty:

The main issue with the current setup is the low frame rate. I managed to increase it using TensorRT and compressing the images in and out, but there’s still a lot of room for improvement.

For those of you that are interested in creating your own or contributing, here are the details:

Here’s a fun Hacker News thread about the project.

Update: January 5th 2025

The project generated some traction following the Hacker News post. I got a couple of unexpected orders, which prompted me to build a cleaner shippable version. Manipulating the original device required holding the electronic components together and hoping they don’t fall out before placing it against the wall. Plus, using a normal Pi for something as simple as calling an API and displaying images seemed overkill and expensive. Finally, the cable situation was pretty bad. I also took the opportunity to clean up the code and implement some of the easy changes suggested by readers of the HN post. The FPS is higher now, although for some reason it’s still much higher on a laptop than on the Pi Zero. I expect this to be relatively easy to fix though.

I first started this second version of the device by CADing up the purchased parts on Fusion 360. I then iterated four times on the custom parts (ie. printing and letting physics compute my mistakes for me) before converging on two 3D printed mounts and a laser-cut back panel. Here’s what the mounts do:

A key aspect to shippability that I discovered while working on it was the question of user affordance. On the first version I was using a bluetooth mouse and keyboard pre-configured using the Pi’s USB ports. But assuming that the user receiving a new device would unscrew the back panel, plug a USB hub, hook up a wired mouse and keyboard, and set up a bluetooth pair seemed like really bad practice. To avoid all that, I added a WiFi dongle to have the Pi act both as an access point to which the user can connect to upon receiving the device via SSH, and still connect to the internet using the Pi’s original network interface.

For more details on how to make your own device you can check out the repo here. If you would like me to make you one, you can email me.


*Technically, learning in high dimension always amounts to extrapolation.