Sharing my unorthodox home setup, and how I use local LLMs

Posted by SomeOddCodeGuy@reddit | LocalLLaMA | View on Reddit | 32 comments

So for the past year and a half+ I've been tinkering with, planning out and updating my home setup, and figured that with 2025 here, I'd join in on sharing where it's at. It's an expensive little home lab, though nothing nearly as fancy or cool as what other folks have.

tl;dr- I have 2 "assistants" (1 large and 1 small, with each assistant made up of between 4-7 models working together), and a development machine/assistant. The dev box simulates the smaller assistant for dev purposes. Each assistant has offline wiki access, vision capability, and I use them for all my hobby work/random stuff.

The Hardware

The hardware is a mix of stuff I already had, or stuff I bought for LLM tinkering. I'm a software dev and tinkering with stuff is one of my main hobbies, so I threw a fair bit of money at it.

Total Hardware Pricing: \~$5,500 for studio refurbished + \~$3000 for Macbook Pro refurbished + \~$500 Mac Mini refurbished (already owned) + \~$2000 Windows desktop (already owned) == $10,500 in total hardware

The Software

The Setup

The Mac Mini acts as one of three WilmerAI "cores"; the mini is the Wilmer home core, and also acts as the web server for all of my instances of ST and Open WebUI. There are 6 instances of Wilmer on this machine, each with its own purpose. The Macbook Pro is the Wilmer portable core (3 instances of Wilmer), and the Windows Desktop is the Wilmer dev core (2 instances of Wilmer).

All of the models for the Wilmer home core are on the Mac Studio, and I hope to eventually add another box to expand the home core.

Each core acts independently from the others, meaning doing things like removing the macbook from the network won't hurt the home core. Each core has its own text models, offline wiki api, and vision model.

I have 2 "assistants" set up, with the intention to later add a third. Each assistant is essentially built to be an advanced "rubber duck" (as in the rubber duck programming method where you talk through a problem to an inanimate object and it helps you solve this problem). Each assistant is built entirely to talk through problems with me, of any kind, and help me solve them by challenging me, answering my questions, or using a specific set of instructions on how to think through issues in unique ways. Each assistant is built to be different, and thus solve things differently.

Each assistant is made up of multiple LLMs. Some examples would be:

The two assistants are:

  1. RolandAI- powered by the home core. All of Roland's models are generally running on the Mac Studio, and is by far the more powerful of the two. Its got conversation memories going back to early 2024, and I primarily use it. At this point I have to prune the memories regularly lol. I'm saving the pruned memories for when I get a secondary memory system into Wilmer that I can backload them into.
  2. SomeOddCodeBot- powered by the portable core. All these models run on the Macbook. This is my "second opinion" bot, and also my portable bot for when I'm on the road. It's setup is specifically different from Roland, beyond just being smaller, so that they will "think" differently about problems.

Each assistant's persona and problem solving instructions exist only within the workflows of Wilmer, meaning that front ends like SillyTavern have no information in a character card for it, Open WebUI has no prompt for it, etc. Roland, as an entity, is a specific series of workflow nodes that are designed to act, speak and process problems/prompts in a very specific way.

I generally have a total of about 8 front end SillyTavern/Open WebUI windows open.

How I Use Them

Roland is obviously going to be the more powerful of the two assistants; I have 180GB, give or take, of VRAM to build out its model structure with. SomeOddCodeBot has about 76GB of VRAM, but has a similar structure just using smaller models.

I use these assistants for any personal projects that I have; I can't use them for anything work related, but I do a lot of personal dev and tinkering. Whenever I have an idea, whenever I'm checking something, etc I usually bounce the ideas off of one or both assistants. If I'm trying to think through a problem I might do similarly.

Another example is code reviews: I often pass in the before/after code to both bots, and ask for a general analysis of what's what. I'm reviewing it myself as well, but the bots help me find little things I might have missed, and generally make me feel better that I didn't miss anything.

The code reviews will often be for my own work, as well as anyone committing to my personal projects.

For the dev core, I use Ollama as the main inference because I can do a neat trick with Wilmer on it. As long as each individual model fits on 20GB of VRAM, I can use as many models as I want in the workflow. Ollama API calls let you pass the model name in, and it unloads the current model and loads the new model instead, so I can have each Wilmer node just pass in a different model name. This lets me simulate the 76GB portable core with only 20GB, since I only use smaller models on the portable core, so I can have a dev assistant to break and mess with while I'm updating Wilmer code.

2025 Plans

Anyhow, that's pretty much it. It's an odd setup, but I thought some of you might get a kick out of it.