CopyLeft Trolls, AI, Lesser Evils of Autocorrect and OCR

This is likely to be a rambly kind of a post.  I typed the blog title first, but, as Hector Barbosa might say, they’re more of what you’d call guidelines than actual titles.  Fair warning – as at least one reader will point out, this may be some more AI bellybutton gazing.1

I basically stopped using Creative Commons pictures in my blog posts and websites a few years ago when I learned of some CopyLeft troll nonsense litigation.  I did my best when using these pictures to provide proper attribution and even wrote a WordPress plugin to help others do the same.2  Learning that a picture from Flickr or posted for free use under Creative Commons could lead to abusive litigation and extortion was so disheartening that I pulled a lot of pictures from my various blogs and either left them with no images, broken images, or if they were very important to the post/page making something to go there.  From that point, I generally trended towards using/making memes to add visual interest to the blog posts.

I was reminded of this after reading a well written post on Mastodon about various alternatives to using AI generated images in blog posts.3 While I don’t think these are all necessarily practical when it comes to finding an appropriate and aesthetically pleasing image to go along with a blog post, I thought this was a worthwhile and thought provoking suggestion.

I do like adding pictures because it adds a little bit of visual interest to what would otherwise be a wall of text.  Many times, I will add a screenshot from OpenSCAD or a photo of a sketch / sketchbook page.  And now, a short digression…

Someone far more pithy than I comment recently that twenty years ago regular people were sued for posting song lyrics, sharing MP3’s of music, and low quality movies, while these days people are becoming AI millionaires by shoveling the entire internet and the collected written works of the human race into machines.

…What should people opposed to AI slop do, then?  Do we stop driving because of license plate scanners and stop going out in public because some asshole will be wearing Google Glass Goggles or Facebook Meta Glasses and feeding our information into facial recognition software? 45 I don’t share photos of myself or family on social media, but should we not store our photos in the cloud and avoid fun community events at the local library?  Even writing this post, I’m  unwillingly contributing the corpus that will be fed into the next version of an LLM.

I feel damned either way.  If I don’t use any LLM, they will consume my writings and original pictures, use my original pictures to track me across the internet, sell me things or sell me to other things.  If I do use an LLM it will do all of that plus train on my interactions.

What is the most defiant thing to do when this blog post is almost certainly going to be read by more web crawlers, spam robots, and LLM’s than humans?  Should I only post new pictures to add visual interest to my posts at the expense of embedding even more meta data into each post?  Is it more subversive to use an AI to generate a fitting copyright-free but soulless image that adds little new information to the algorithm’s endless hunger?

I don’t have answers to any of this.

As I was working yesterday another thought occurred to me.  Where is the line between “software” and “LLM/AI”?  I had just run optical character recognition on a large document to help figure out what was in it.  All OCR is just pattern recognition, making trained “black box” guesses at what’s a given letter/word/pattern.  I’ve never liked the auto-suggest “feature” of my phone’s texting app or gmail, but I like the auto-complete feature of LibreOffice when I start to type a date.  I don’t mind when my text editor suggests the name of previously used variables and functions – it’s actually quite helpful.

Why am I comfortable with an heuristic’s OCR/autocompleting dates/autocompleting variable/function names, but I hate auto-suggesting messages?  Perhaps because it’s no something I can turn off.  I just know I find these kinds of “helpful suggestions” to be far more intrusive.  Maybe I don’t mind these helpers in documents – but I don’t want them stepping the communications between myself and another human?

I don’t mind using an AI image generators for a stupid joke, but I hate seeing them in advertisements.  I would never use an AI, local or otherwise, to write something to someone I loved, client, colleague, coworker – but I don’t mind it when I’m trying to wrap my mind around a new API, updating an old program when certain parts I’d written are now deprecated, or even writing something in a brand new language.  It’s hard to tell if I’m justifying my uses or if there really is a decent use case for these things.

I guess I’m trying to come to terms with what kinds of AI/heuristic usages I like, am ambivalent towards, and those I hate – to better understand why I feel/think these ways.

  1. Hi Pete! []
  2. More than twelve years ago now! []
  3. TLDR:  Take a picture, use Wikimedia Commons, screenshot from video game, lego diorama, use art supplies/image program to make a picture, stickers, pictures of a shelf. []
  4. I read once that Meta had figured how to associate photos with people based upon the scratches and dirt on the lenses from photos that had been uploaded! []
  5. This is why I generally rescale/blur/distort images before posting them online.  But, I mean, how much time am I going to devote to this if I just want to share a quick picture of something? []

Not Team AI

Look, I hate AI slop as much as the next person.  My kiddo has been taking a college class where they’ve been delving to the ideas swirling around AI/LLM’s and from what I gather, the class is nearly incomprehensible.  Just like my toaster, oven, toaster oven, fridge, and dryer don’t need wifi – neither does every damn thing need a thick coating of AI slop all over it.

Another Marvel reference?

I’ve been thinking about AI as a variation on the “super soldier serum” administered to Steve Rogers.  Given to a good man, he can be better.  Given to the Red Skull, well, he gets worse.  Instead of only making things better, it seems to simply magnify the attributes of a thing.

I guess I’m struggling with the idea of whether it’s hypocritical of me to use AI for things when so often it just makes things worse. 1  And, I admit it is fairly self-serving to liken my uses to that of Steve Rogers and assign derogatory attributes to other uses.

Maybe it’s that I’m using AI/LLM’s to add micro improvements to my own life, rather than pushing it on others?  After trying to work with free AI’s on some projects, I decided to pay $20 for a month of premium Claude Pro access.  While using the free ones, I discovered:

  • Claude’s free chat would lock a conversation after a certain context length if you uploaded any documents
  • Gemini would time-gate a conversation by not letting you use it after a certain amount in a given period
  • ChatGPT would time-gate a conversation if you uploaded anything, but would merely drop to a lower power model if you didn’t upload content and instead just worked through the chat interface

Overall, ChatGPT was more useful as long as I didn’t upload anything, and I could “make do” with the lower tier models.  I’d paid for the premium tier of ChatGPT for a few months about two years ago and quickly became disillusioned with it.  I found that it would start to chase it’s own tail, forgetting the thread of a conversation and project, randomly refactoring stable code, hallucinating functions, variables, and the names of functions and variables.  It was more work to keep it on the rails than it was to simply just work on my project.  I ended up largely shelving several projects as a result.  I’d tried unsuccessfully to hire someone, I didn’t have the time to work on them by myself, and sure as hell didn’t have the bandwidth to baby sit2 an LLM.

However, working with various LLMs recently gave me a glimmer of hope.  Perhaps they could be useful after all?  Pouring over documentation, searching for answers, and consulting Reddit and StackOverflow were options, but they all had their special problems.  In any case, these days all of these options (except documentation)3 were getting more difficult to use as people started abandoning public forums in favor of just asking an AI.

One of my favorite XKCD comics :)

So, what have I been working on?  Well, I signed up for Claude Pro on 02/09/2026 and in the just over three weeks since then:

  1. WordPress Plugin.
    1. An overhaul of a website’s registration system.  I had been using a now-defunct WordPress plugin on a different website which was basically crumbling to pieces as WordPress and the world moved on.  My needs were simple – so a few days of tinkering with Claude Pro got me something that … just worked for my purposes.  It eliminated all spam robot signups in a way that nothing I’d tried before had been able to manage.  There were a lot of moving pieces to this plugin, and there was certainly some growing pains, but it worked very well, very quickly.  I have built plugins for WordPress before and could well do so again even without an AI, but the speed of the model to build all the trivial or tedious stuff is by definition super-human.  Since the site’s ability to turn visitors into users into (hopefully) a few dollars is dependent upon the ease of registering, this one single change easily justified the $20 cost of using Pro.  That $20 accelerated this from a project I’ve been putting off for literal years because I knew how long it would take me alone, to … solved in a few days.
  2. Python Assistant Script.
    1. As a friend was quick to remind me, I’m very late to the voice activated computer assistant / smart home party.  I’d been working on a version of this with three free frontier LLM models, but it was too much, spread across too many platforms to be really cohesive or stay undamaged by converting parts among through these resources.  Progress on this project has been slower than building a single WordPress plugin, but it has definitely been boosted.  I regularly have to join online meetings where the information to join is sprinkled like breadcrumbs across multiple disparate pages on a given website, sometimes requiring a pseudo-registration process to reach.  Doing all these things manually is a real headache when I haven’t had my morning coffee.  And, let’s be honest, it’s way more fun to throw hours at a problem figuring out how to solve a problem than it is to actually face one’s problems.  I would estimate that this feature will save me about 15 minutes once a week.  Using the above XKCD logic, I’m time/energy/effort-positive if I could built this feature in less than 5 days.  I probably got it working in a few hours.  At the same time, I’ve been “bolting on” new features – a scheduler, time queries, weather queries, media control over my computer, with more features on the way.4
  3. A YouTube Management Chrome Plugin.
    1. I have this unfortunate habit of keeping too many tabs open.  While this is bad enough, keeping a lot of YouTube tabs open will have a huge impact on system memory very quickly.  I didn’t have the time at the moment to watch the videos, didn’t want to lose these videos, and didn’t want to go through the hassle of adding them to playlists.  Instead, apparently I had enough time to build a Chrome plugin that would go through all of my tabs, bookmark each one to a special bookmark sub-folder, sort them into sub-folders, and then close those tabs.  I don’t know that this will ever “save” me time, but it certainly is helping my system work better and keep my tab monster from getting too far out of control.  However, I think I’m going to extend this plugin to be a little more practical.  I think it could work for more than just YouTube videos to mass-close tabs, bookmarking them so they’re not lost, then sorting them into sub-folders.
  4. Email Entries for Work.
    1. My day job requires entry of data into a web portal.  It’s a good content management system, but not great for data entry.  It’s designed for humans to insert data, slowly, one entry at a time.  The UI requires a couple of duplicate keystrokes and/or mouse clicks.  While I deeply dislike having to do something stupid even once.  I absolutely loathe having to do something stupid twice.  It’s basically my kryptonite.  Rather than enter emails into this system, which I fucking hate, I wrote a Python script to pull data from Outlook into a CSV, export the email data into an HTML file which reviews each email and suggests an entry code for each one, and once that data’s been cleaned/formatted, which I upload into a script that I wrote to work with my employer’s website, then begin the process of uploading each one.  Since the data entry website has all kinds of dynamic elements and animated features, I can’t simply populate fields – I have to give each one time to load.  Instead of just uploading an Excel/CSV sheet, I have to wait for each entry to play it’s little animations, time the data to populate, and then click each one manually to enter because the animations sometimes don’t work well.  However, it’s a million times less painful than having to type all this bullshit in myself.
    2. Don’t worry, I don’t upload any of my email or data into any LLM.  All the logic which pulls data out of my Outlook and builds things out of it runs on my local machine.

I never could have built so much, so fast, without the help of a frontier AI.  None of the local LLM’s I’ve tried got even close and none of the free-level AI’s could maintain coherence long enough to help.

Claude Pro isn’t without it’s problems – I still had to monitor the code closely, keep it from forgetting certain key features, and deciding to completely refactor the code.  At the $20 level, I can choose among several different models that are supposedly different levels of quality and consume higher amounts of tokens, and I’m limited to a certain amount of compute within a 4 hour window and limited to a certain amount each week.  Even so, I’ve had more than enough compute for the tasks I’ve been doing.  While these things have been super helpful to me… none of them are cutting edge research or huge trade secrets.  In the chat interface you can switch language models, but doing so requires your conversation restart in a new conversation entirely.  In Claude Code you can switch the models, but I feel like the LLM lost the thread a little when I did this.

I am a frugal man and tried to do this with free LLM access, but the benefit of more capable, more coherent models, with increased ability to share an entire code base (with the help of Claude Code + Github) for $20 has been an unbeatable deal.  I’ve got a few ideas for some additional projects that could benefit from keeping the subscription going and will probably give it another month.  I don’t know that I’d need year-round access though.

Software Development with LLMs
  1. Series Plugin Test for Illustrative Purposes Only
  2. ChatGPT WordPress Plugins
  3. Coding with an LLM Sidekick
  4. Python Practice with an LLM
  5. Not Team AI
  6. Never Stop Breaking Up
  7. Weakness
  1. “Do I contradict myself? Very well then I contradict myself, I am large, I contain multitudes.” – Walt Whitman []
  2. And, let’s be real – train []
  3. RTFM, I guess []
  4. Screenshots, giving me a daily briefing, etc []

Series Plugin Test for Illustrative Purposes Only

The only purpose for this post is to serve as a reference for a more interesting and useful post.

Software Development with LLMs
  1. Series Plugin Test for Illustrative Purposes Only
  2. ChatGPT WordPress Plugins
  3. Coding with an LLM Sidekick
  4. Python Practice with an LLM
  5. Not Team AI
  6. Never Stop Breaking Up
  7. Weakness
Software Development with LLMs
  1. Series Plugin Test for Illustrative Purposes Only
  2. ChatGPT WordPress Plugins
  3. Coding with an LLM Sidekick
  4. Python Practice with an LLM
  5. Not Team AI
  6. Never Stop Breaking Up
  7. Weakness

[custom_pdf_generator visitor_data=“John Doe”]

 

Test