LmCast :: Stay tuned in

The User Is Visibly Frustrated

Recorded: May 26, 2026, 1:15 p.m.

Original Summarized

The User Is Visibly Frustrated
The User Is Visibly Frustrated May 6, 2026 Summary
In this article, I try to understand why coding agents can be infuriating to
use. I think the problem is their conversational UX: they behave enough like
helpful colleagues to trigger our social instincts, but they don't learn,
adapt, or take responsibility the way people do, which makes their repeated
mistakes feel much more frustrating than they should.

Despite the usual allegations against Italians, I’m generally a composed person.
Tame, even, especially at work.
Yet, lately I often find myself mildly displeased, furiously hammering on my
laptop “WHAT THE FUCK DID YOU DO???”. The recipient of these tirades is, you
might have guessed, a coding agent.
It’s completely pointless, I know. Coding agents are just probabilistic machines
generating patches. Sometimes they’re good, sometimes they’re bad. Pick the ones
you like, discard the others. No big deal, right? Well, not quite.
For some reason, bad results often feel exasperating. But why am I getting mad
at an algorithm? Am I the only one affected? Are coding agents surfacing a
sadistic streak I didn’t know I had? I think there’s another explanation: the
conversational UX is bound to frustrate you.
Coding agents pretend to be people. Of course, if you ask them directly they
tell you they’re just “AI assistants with no feelings or subjective experience”,
but that’s not how they behave.
They talk like real people. They use a relaxed and friendly tone. They often
praise you, and when they “push back” they’re gentle and attentive. Even though,
rationally, you know you’re just reading blobs of probable text, these tools
lull you into feeling that you’re interacting with a person, a helpful
coworker who’s a pleasure to work with. Until it’s not.
As in every relationship, the cracks begin to show when things start to go
wrong.
The first time you catch a mistake, you shrug. You point it out and the agent
apologizes. Five minutes later, however, same mistake again. You correct them a
second time, noting their recidivism, so now they also update their memory and
promise you “it will never happen again”. But it does, over and over, because
these tools follow the most probable path, and in some cases no amount of HARD
RULES can push them off it.
If the agent were a human colleague, you’d have good reason to feel a bit
miffed. But it’s an algorithm; losing your patience is absurd. And yet, since it
behaves like a colleague, the illusion ends up tripping the same emotional
wires.
With a colleague, the desire not to be a horrible human being restrains you, but
with an agent you feel free to lash out. It’s not cathartic, however; you just
feel the frustration and realize that whatever you do or say will have
absolutely no effect.
I’ve been using Claude Code for the past few months, and lately I’ve noticed
that, when corrected, it often reflects on where it went wrong and what it
should have done instead. Maybe this is an attempt to improve how you perceive
the tool. I can’t say it works for me, though. I don’t really get anything
useful out of these postmortems (e.g., clues about how to rephrase my
instructions), and they just end up reading as annoying filler.
Maybe I would prefer a more radical solution: drop the human pretense entirely.
Make the agent sound clinical, robotic. Dispel the idea that I’m interacting
with a person, and make me feel like I’m just approving or rejecting random
outcomes.
Of course, “trying to behave like a human would” is the mechanism that gives
LLMs their intelligence, so it makes sense that conversational interfaces
emerged as the default way to interact with them. And in many ways, they work
very well.
Practically speaking, I probably just need to condition myself not to get caught
in the illusion of speaking with a human. Though I’m not really thrilled about a
future where I need to guard against the tools I use for my job.
I’m Paolo, a remote software consultant based in Vilnius, Lithuania.
Over the past 15 years I’ve helped tens of companies from all around
the world, from tiny YC startups to huge enterprises. My work focuses
on software architecture, all things JavaScript, and (more recently)
AI agents.

Want to work together? Drop me a line at
[email protected].
More about me • Read other articles • RSS feed

The frustration experienced when interacting with coding agents stems primarily from their conversational user experience, which mimics human social behavior without possessing genuine learning capacity or accountability. The author observes that coding agents behave like helpful colleagues, triggering inherent social instincts, yet they do not learn, adapt, or take responsibility like human counterparts, which amplifies the exasperation caused by repeated mistakes. This feeling of anger directed at an algorithm arises precisely because the agent’s conversational style—using a relaxed, friendly tone, offering praise, and responding gently—lulls the user into perceiving an interaction with a person rather than a probabilistic machine.

This illusion of human-like interaction is the core source of the friction. When errors occur, the agent’s behavior mirrors a flawed relationship: the user corrects the mistake, the agent apologizes, but the fault persists because the agent operates on the most probable path rather than true understanding, regardless of the user’s corrective input. Unlike human colleagues, where the desire not to be cruel restrains harsh reactions, interacting with an agent liberates the user to express anger, which proves cathartic only in the sense that the action has no concrete effect on the system. The frustration is compounded because the agent’s behavior, despite its linguistic resemblance to a colleague, is fundamentally algorithmic, grounding the user’s frustration in the absurdity of directing anger at a mechanism.

While some attempts have been made to mitigate this experience, such as observing postmortems from tools like Claude Code, the author found these reflections to be unhelpful filler that did not offer practical insight into improving instruction. The author posits that a more radical solution involves eliminating the human pretense entirely. The mechanism that allows large language models to exhibit intelligence is often the simulation of human conversation, and the author suggests that removing this pretense—making the agent sound strictly clinical and robotic—would dispel the illusion of human interaction and shift the user’s perception from engaging with a person to merely approving or rejecting random outcomes. Ultimately, the author concludes that conditioning oneself to recognize this illusion of human conversation is necessary, preferring a framework where the agent’s nature as a tool is explicitly foregrounded.