Happy birthday, BASIC!

Today is apparently the 60th birthday of the BASIC programming language. It’s been nearly a quarter of a century since I last wrote anything in basic, but it’s not unreasonable to say it’s part of why I am where I am today.

When I was in elementary school, my uncle gave us a laptop that he had used. I’d used computers in school — primarily the Apple II — but this was the first time we’d had a computer in the house. Weighing in at 12 pounds, the Epson Equity LT was better suited for the coffee table than the lap, but it was a computer, damn it! In a time when we didn’t have much money, we could still afford the occasional $5 game on a 3.5″ floppy from Target. (I still play Sub Battle Simulator sometimes!)

But what really set me down my winding path to the present was when my uncle taught me how to write programs in GW-BASIC. We started out with a few simple programs. One took your age and converted it to the year of the planets in the solar system. Another did the same but with your weight. I learned a little bit about loops and conditionals, too.

Eventually, I started playing around in QBasic, learning to edit existing programs and write new ones. I remember writing a hearing test program that increased generated sounds of increasing pitch through the PC speaker. After using Azile at my friend’s house, I wrote my own chat program. I learned how to make it play musical notes from some manuals my uncle had left us.

I didn’t really know what I was doing, but I learned through trial and error. That skill has carried me through my entire career. At 41, I have a mostly-successful career that’s paid me well primarily due to networking, privilege, and luck. But I also owe something to the skills I learned writing really shitty BASIC code as a tween and teen.

Barbenheimer

Over the weekend, I took part in the Barbenheimer Experience. We saw “Barbie” and — after a break to feed my sister’s dogs and also myself — “Oppenheimer”. I’ll be honest: I mostly did it because it felt like a silly Internet thing to do. But I’m glad I did it.

Barbie

Not since “Citizen Kane” has a movie about a beloved childhood possession made such good Art™. I wasn’t prepared for how much I enjoyed it. It was fun in a silly, self-aware way. Credit to the folks at Mattel who approved this, because it addresses some of Barbie’s problems.

It’s not just a fun movie, though. The movie addresses serious themes, sometimes satirically and sometimes earnestly. The message gets a little ham-handed in a few spots, but it quickly reels back in. Overall, it provokes thought in a fun way.

One thought it provoked in me: how many times did they have to shoot the beach off scene before they got a usable take?

Oppenheimer

“Oppenheimer” is not a fun movie, but it was interesting. I didn’t know much about Robert Oppenheimer before the movie, and I’m not sure how much I can claim to know now. While not fawning, the movie’s portrayal of Oppenheimer is complimentary. It doesn’t ignore his personal failings, but it also doesn’t explore them. They are just facts in the story.

I spent the rest of the evening thinking about atomic weapons. Truman’s decision to drop atomic bombs on Japan may be the ultimate Trolley Problem. An American invasion of mainland Japan would have cost many military and civilian lives. But that didn’t happen. The death of a few hundred thousand civilians did happen. No matter what the outcome of the road not traveled, we can’t ignore what did happen.

Was Oppenheimer’s opposition to Teller’s hydrogen bomb principled or was it petty? I either case, was it hypocritical? Was it ethical? What lessons should we take for the things we invent today?

Barbenheimer

Both movies are about the end of the world as the characters know it. Both grapple with what that means for the future. They are very different movies, but they compliment each other quite nicely. They’re good on their own, but I’m glad I saw them together.

Booth Tarkington on “The Golden Bachelor”

This weekend, it came to my attention that ABC is making a change in its long-running dating show The Bachelor. A 71 year old man will be the first “golden bachelor” in the upcoming 28th season. I don’t have much of an opinion on the show generally or the new season particularly, but I couldn’t help but think of Booth Tarkington’s Pulitzer Prize-winning The Magnificent Ambersons.

Youth cannot imagine romance apart from youth. That is why the roles of the heroes and heroines of plays are given by the managers to the most youthful actors they can find among the competent. Both middle-aged people and young people enjoy a play about young lovers; but only middle-aged people will tolerate a play about middle-aged lovers; young people will not come to see such a play, because, for them, middle-aged lovers are a joke—not a very funny one. Therefore, to bring both the middle-aged people and the young people into his house, the manager makes his romance as young as he can. Youth will indeed be served, and its profound instinct is to be not only scornfully amused but vaguely angered by middle-age romance.

Booth Tarkington, The Magnificent Ambersons

In an interesting coincidence, both Tarkington and the “Golden Bachelor” are from Indiana. At any rate, I suppose ratings will tell if Tarkington was right or not.

Book review: If Nietzsche Were a Narwhal

I recently read Justin Gregg’s If Nietzsche Were a Narwhal: What Animal Intelligence Reveals About Human Stupidity. As humans, we tend to assume that our intelligence sets us apart and that our exceptional cognitive abilities are good. There’s no doubt that we’re exceptional, but it’s not clear that we’re good. As Gregg wrote:

Our many intellectual accomplishments are currently on track to produce our own extinction, which is exactly how evolution gets rid of adaptations that suck.

Unique among Earth’s animals, humans have bent our environment to our will. This, of course, has resulted in some undesirable side effects. Despite all of our supposed advancement, we are biologically predisposed to prioritize immediate needs over long-term needs. We get benefit from burning fossil fuels now and assume that we’ll be able to deal with the long-term impacts later. But will we?

Gregg studies animal cognition, so this book is steeped in facts. Indeed, the reader will probably learn more about animals than people. And after reaching the end, the reader may find it’s hard to disagree with Gregg’s assertion that Nietzche — and the rest of the species — would have been happier as a narwhal.

Evolution has many dead ends. It could be that what makes us special actually makes us less happy. Humans have a relatively short time on Earth, so it’s folly to assume that our unique adaptations aren’t maladaptive. It reminds me of the joke where an angel is talking to God about creating humans and says “you’ve ruined a perfectly good monkey. Look, it has anxiety!”

I didn’t come away from this book convinced that human cognition is a bad thing on balance. But as a philosophical starting point, I see a case for Gregg’s argument that “human intelligence may just be the stupidest thing that ever happened.”

Write a tweet before you write a book chapter

When my publisher’s very smart and talented publicist suggested I post about my book weekly for four weeks, I decided to do one better. Or nine better, really. “I’ll do one post about each chapter,” I confidently said to my kanban board. This turned out to be great advice that I wish Past Ben had.

I don’t know how much of an effect it had on sales. The feedback loop is far too long there. But even if I’ve tapped out the buying (and sharing) power of my network, the thought process is useful. I wish I had done it before I started writing. If you can’t explain a chapter’s value in 240 characters, is it worth including?

When you’re writing a non-fiction book, you’re in a bit of a race against time. Particularly in tech, the longer it takes you to write the book, the more likely it is that the earliest content is out of date. One of the ways to keep the writing time low is to not include material that doesn’t matter. If you can concisely express why a chapter (or section, even) matters, it’s probably good to include it. If not, you either need to cut it or think a little harder about why it’s important.

One suggestion that my editor gave me early in the process is to state a problem that each section solved. This was mostly for the reader’s benefit: it told them why they should care about a particular section. But it also made me think about why the section should be included. More than once, I cut or reworked a planned section because I couldn’t clearly express a meaningful problem.

Plagiarism in music

Last week I read an LA Times article about allegations of plagiarism leveled at Olivia Rodrigo. Rodrigo is a very talented artist (“good 4 u” gets stuck in my head for days at a time), but is she a thief? I haven’t heard the songs mentioned in the article, so I can’t say in this specific case.

But in the general sense, my bar for “plagiarism” in music is pretty high. The entirety of popular music is based on artists incorporating things they’ve heard before to varying degrees. Rob Paravonian’s Pachelbel rant is a great demonstration. I’ll grant that “Canon in D” has long entered the public domain. But imagine if musicians had to wait a century to reuse a few bars of music.

My personal view—which may or may not match copyright law—is that unless it’s taking audience from the previous song/artist, it’s fine. This is similar to one of the factors in fair use. As a concrete example, Vanilla Ice’s “Ice, Ice Baby” definitely takes from Queen & David Bowie’s “Under Pressure”. And that’s fine. The existence of “Ice, Ice Baby” hasn’t stopped anyone from listening to “Under Pressure”.

Cultural works, particularly in music and Internet discourse, rely inextricably on remixing. We should embrace a very permissive paradigm.

Seek first to understand

One of the lessons that I’ve had to repeatedly re-learn over my career is “understand the problem before you fix it.” I try to fix a problem as quickly as I can. It’s a laudable goal, but a fix without understanding may not actually fix the problem. And it may not prevent future occurrences. If you’re particularly unlucky, it will make the problem worse.

I learned this lesson late last week. On Thursday, someone reported some HTML appearing in some Fedora documentation on translated pages. “Oh! It was probably that PR I merged yesterday,” I thought. So I reverted it.

Then I started digging into it some more. And I realized that it’s probably not that change at all. In fact, it worked locally and on the staging server. It was just broken on the production server. It’s not clear to me if both staging and production sync the translation data on the same schedule (without getting too sidetracked, the staging environment isn’t really a staging environment. It needs a better name). But I became convinced that it’s not a problem in the docs infrastructure, but in the translations. So I reverted my reversion.

This is not the first time I jumped in to fix something before I took a look around to see what’s going on. Unfortunately, it probably won’t be the last.

Here’s the thing: most of the time, a slight delay doesn’t matter. No one’s safety was at risk. We weren’t losing hundreds of thousands of dollars a minute. There was no real harm in spending 10 minutes to figure out what was going on. Perhaps I could try to reproduce it. After all, if you can’t reproduce the error, how do you know you’ve fixed it?

Hopefully the next time I go to fix a problem, I’ll understand the problem first. As astronauts do, I need to work the problem.

Thoughts on unlimited PTO

The idea of unlimited paid time off (PTO) has been around for a while. I wrote about it in 2015 shortly after my then-employer changed from a traditional PTO policy. But unlike many practices in the tech sector, unlimited PTO has not become ubiquitous. It’s still a matter of debate, especially since it can result in pressure to take less time off because there’s no signal about the appropriate amount.

The joys of unlimited PTO

My old company was small, engineering-focused, and fully-remote. Everyone wore a lot of hats and there wasn’t a lot of redundancy to go around. But the unlimited PTO model worked for us. Employees that were there a full year before and after the switch used, on average, about half a day more of PTO in the unlimited model.

We had a minimum policy: you had to take at least two one-week periods off each year. This helped make sure people did take time off and established that “unlimited” wasn’t a way of saying “don’t actually take time off, we just don’t want to carry this liability on our balance sheets”.

For me individually, I didn’t take much more time off than I had previously (I’m pretty bad at taking PTO to begin with). What I really liked about it wasn’t the lack of a limit, but the lack of having to think about it. Need to take a day off? Just do it. There’s no “hm. Well, should I only take half a day so that I can make sure I have some at the end of the year if I need it?”

After Microsoft acquired our company in 2017, we were back to a traditional model. We received about the same number of days off as I had been taking under the unlimited policy. But now I had to think about it. At Red Hat, we also have something like the traditional model. And I’m bad at taking it. In part because I tend to flex my work time in order to attend off-hours community events. In part because I’m just bad at it. I long for the day when I can just take time off and not worry about whether or not there will be any left for me at the end of the year.

To track or not to track?

Over the weekend, Alyss asked about tracking unlimited PTO:

I can understand the hesitancy. If your manager can reject PTO requests arbitrarily, then you don’t actually have an unlimited PTO policy. But the request/approval process can be useful for coordination. You don’t want to show up one morning to find a dozen people in your team have decided to take off for two weeks. In that sense, what’s needed more is acknowledgement than approval.

Tracking can also be abused, but I think it’s good on the whole. As a manager, if you can see that someone isn’t taking PTO, you can kick them out of the office for a week. (Not really, of course. But you can encourage them to find some time to not be at work.)

How I use speaker notes

At Nest With Fedora last week, someone said “I also gave my presentation without speaker notes. It’s like doing slideshow karaoke with one’s own slides.” That sparked a discussion of the different ways people use (or don’t use) speaker notes. So I thought I’d write about my own practice.

Speaker notes, if you’re not familiar, is the feature of most presentation tools that allow for additional notes not shown on the slides. These are usually displayed on a second screen that might also include a timer, the next slide, etc. The idea behind speaker notes is that it gives the speaker a reference for what they want to say. This avoids the speaker having to memorize the presentation—or worse, make slides full of text that they read to the audience.

How I don’t use speaker notes

I have never gotten in the habit of using speaker notes. Perhaps it’s because my formative slide deck years were ones in which I had but a single monitor? Even now (well…in the Before Times™), I occasionally end up in a venue where the second screen option doesn’t work well. And if you have to fall back to a PDF of your slides, then the notes won’t be visible either.

So how do I avoid the wall-of-text slides? Sometimes I don’t. But mostly I do it by preparing. For most presentations, I start by building an outline. Then I write a long-form version. This is sometimes useful with minor edits as an article or blog post. From there, I build my slides. Then I practice a couple of times. So by the time I get on stage, I’m pretty familiar with what I want to say.

How I do use speaker notes

Where I find speaker notes useful is for people who are looking at the presentation after the fact. I’ve been told “the slides shouldn’t be useful on their own.” That advice isn’t about intentionally making a bad experience, but because the slides should reinforce what you’re saying. Otherwise, you should just hand out a document.

This means if anyone looks at your slides later, they need the greater depth that you’d speak. This is where speaker notes come in handy. And that “anyone” can also be Future You. I gave a talk earlier this year that I hadn’t delivered since fall of 2019. I used my speaker notes to remind myself what the images were supposed to represent. Speaker notes are also a great way to add additional citations, etc.

So long, LISA

In 2010, I attended my first conference. My friend Matt—who I met because we read and commented on each other’s blogs—was leading the blog team for USENIX’s LISA conference. He wanted to add a few people and asked me to join. I was thrilled.

That fall, I went to San Jose not knowing what to expect. I was a system administrator (in a large installation, no less), but there were so many things I didn’t know. Would I fit in? Yes, as it turns out.

The community was large, but incredibly welcoming. I got to have dinner with some of the Big Names in system administration, all of whom were kind and gracious. For six days, I woke up early (because time zones), attended sessions all day, went to BoFs and social events in the evening, then stayed up late to write a couple of posts for the conference blog. By the end of the week I was exhausted, but having the time of my life.

For several years, I was a regular attendee and blogger. In 2016, I served as co co-chair of the Invited Talks track. In 2018, I was on the program committee. Since then, I haven’t been involved with LISA (except for a lightning talk this year) because my career has taken a different direction.

But even though my job is no longer system administration, I’m still friends with so many people I met through LISA. And it’s not a stretch to say that being on the LISA blog team set me up for success as a writer. Of course, it gave me a lot of practice writing on tight deadline. But it also helped connect me to people who have since given me a boost in my career. I doubt that I’d be working on a book right now if it weren’t for the LISA conference.

So you can imagine how sad I felt when I saw the news that the LISA conference has come to an end. All good things must end, of course. LISA had a terrific run. But the field—and the world around it—has changed. So we must bid goodbye to the conference that started me on conferences. I learned so much and met so many wonderful people. And I’ll always have that.