I was using LLM frameworks everywhere but had no idea what was happening inside them. One day I needed to optimize something and realized I couldn't. Hard truth: I didn't understand the fundamentals, just which framework function to call.
So I stripped everything away. No abstractions. Just Python, HTTP requests, and the OpenAI/Anthropic APIs.
What I found was anticlimactic in the best way: there's almost nothing there.
  - "AI agents" are just functions the model tells you to call
  - "Memory" is literally just a list you append to and send back
  - "RAG" is search, concatenate to prompt, send it off
  - "Multi-agent systems" are just API calls in sequence
I created 7 modules showing the basics: API calls, conversation state, tool calling, RAG, streaming, prompt chaining. Each one is heavily commented, nothing fancy. Side-by-side examples for Claude and GPT so you can see they're fundamentally the same thing.
Now when I use frameworks, I actually know if I need them or if I'm just adding bloat.
