More important skills/traits in becoming a computer programmer

One of students on the FIRST robotics team I mentor asked “what do you think is the most important skill or trait in becoming a successful computer programmer?”. I wrote a paragraph about persistence, problem solving and attention to detail commenting I’d choose problem solving if I could only pick one. I also immediately thought this would make a good blog post. So expanding on my top three and also commenting on how these are all important even as AI does more of the coding.

Persistence

Persistence because it feels like you are an hour from being done for days if work. Often when something doesn’t work, there are many possible causes. You have to do experiments to rule causes in or out. Getting frustrated is stressful and doesn’t result in the problem getting solved. Persistence lets you keep plugging away at it. This is especially important when there is a tight timeline or a production system is down. You know you have to get it done quickly even if it feels like you have no idea how close you are.

AI impact: Not taking the first answer to a question or the first code that gets created is a form of persistence. Adding details and trying new things to get what you want still matters. Similarly, I’ve gotten AI to give me leads I might not have thought of by using a variety of prompts.

Problem Solving

Problem solving because that’s essentially what we are doing. Getting a computer to do what we want. Taking a bigger problem, identifying smaller ones, coming up with alternatives on how to solve it – all of these require problem solving ability. I’ve often said that I enjoy doing software development because we get paid to solve problems and do puzzles. While they aren’t called puzzles, once you identify the constraints and rules, getting a solution that fits in them feels a lot like a puzzle.

It doesn’t have to be programming either. I am volunteer coordinator for the NYC FIRST Robotics Competition. Making as many people in their volunteer assignments is an interesting puzzle I get to do every year. I’ve used that skill a few times at work when creating teams for team building activities – creating rules to maximize networking while keeping the teams balanced according to a variety of factors.

AI impact: As you advance in your career, problem solving becomes more important. When you start out, the problems are smaller and tasks come with clearer instructions. I think AI makes problem solving a larger portion of the job earlier in one’s career. You spend less time on syntax and more time in specifying what you want and figuring out why it doesn’t work.

Attention to Detail

Attention to detail because getting one line of code or one setting wrong makes the entire thing go klaput. Whether it is reading an APIs documentation or identifying small differences or thinking of every edge case, attention detail is a key skill. Last week, I was in a rush and trying to figure out why my unit test was working on my machine but not on the build server. I suspected a typo but was tired and didn’t see it. I was also too worn out to think of case sensitivity. (If i had, I’d have done a text compare). Instead, I asked a teammate who is the most detail oriented person on the team. I wasn’t even done explaining what was wrong when he said “does the case matter.” Yup!

AI impact: In the past people used books and reference sheets. Then search engines. Now AI. With all of these, you have to deal with situations where noticing small differences can make a huge difference in your productivity.

What does ChatGPT “think”?

After writing this, I asked ChatGPT to see how my answer as an experience professional compares. ChatGPT noted the most important skills for a beginning/early career programmer are ones to help learn, build confidence and develop good habits early. ChatGPT then identified seven.

The top three were the same as the ones I picked. After that were curiosity/willingness to learn, basic technical foundations, communication/help seeking and enjoyment/playfullness.

I agree with these. I didn’t put technology in my answer because the language you learn isn’t the important thing. Technology changes quickly. I do agree that the foundations matter because it enables you to work with any technology.

Interestingly two of the items showed up in my explanations of other items showing I clearly think they are important: help seeking (asking my teammate about the casing issue) and enjoyment/playfulness (we get paid to solve problems/puzzles)

NYC Bus Redesign and a Coding Problem

NYC is updating the MTA (metropolitan transit authority) bus system this summer with one set of changes taking effect today and another taking effect in about two months. How it went from my point of view:

The plan

There were four plans. Lesson: don’t call something the final plan or you have run out of names. My friends and I were wondering what they would call the real final plan “Final final”? They went with “Final Plan Addendum”. I will say the plan was well socialized and communicated.

  • 2019-2021: Draft Plan
  • March 2022: New Draft Plan released
  • December 2023: Proposed Final Plan released
  • December 2024: Proposed Final Plan Addendum released
  • January 2025: MTA Board approved the Proposed Final Plan Addendum

Leading up

For the most part, the MTA was good with signage. Signs for the new bus routes went up early. Existing stops had yellow signs saying if the stop would cease to be a bus stop or if the route was changing. In my neighborhood, there was a campaign a few weeks back in person to make sure people knew.

First day: bus stops

On one of the routes near me, two bus stops with bus shelters are no longer bus stops. One of them is no longer on the bus route. The other is, but not a bus stop. Drivers were good about letting people get on there and letting them know the bus stop moved.

The new bus stop in between these two stops had cars parked there overnight. (There was a sign that said no parking starting Sunday but it was hard to see.) That cleared up over the course of the day. Now, there’s a nice line of people waiting at the bus stop.

It’ll be interesting to see when the MTA takes down the old misleading bus shelters and if they build on at the new one. (I can see the new bus stop from my window so I’m particularly interested in what happens there.)

A new bus route

There’s a new bus route that goes limited stop from 1 or 2 blocks from my apartment to a number of areas that I go. (Whoo hoo! I don’t have to transfer buses to go there anymore. This is going to be great in the winter.)

Wait: did I say 1 *or* 2 blocks. Why yes, I did. The last stop of the new bus route is across the street from my apartment. The first step is … somewhere. According to the MTA it is a t a street corner two blocks away. The apartment building as a sidewalk tent (a type of scaffolding) and there doesn’t appear to be a bus stop there. One bus driver thinks the new bus is sharing a stop with another but even though there isn’t a sign for it there. It’s also possible it loads at the last stop.

This bus only runs every half hour on weekends and I wasn’t prepared to just miss it by waiting at the wrong place. The second stop is only a few blocks away so I waited there. I was fourth on line suggesting I was not the only one with that confusion. The bus came into the second stop with about a dozen people on it. They weren’t sure where the first stop was supposed to be nor was the driver.

I took this same bus home. Where the driver got confused and couldn’t find the last stop. While it is clearly marked, it is the break area for that bus and another one. The other bus was in front of the sign so the driver couldn’t see the stop and pulled onto a side street to look for the non-existent first stop. Which he couldn’t find either.

This feels like growing pains though. Overall, I was happy with the rollout.

Coding bug

The MTA runs a website where you can see when the bus is coming with real time info. It is mostly correct. And then every once in a while you get something like the following. (I’ve seen this problem before so it’s not related to the redesign.

One bus was “3 minutes” away. and just over a mile away. (This is a street where you can go 25 miles per hour and has a lot of lights. You can’t go a mile in 3 minutes unless you catch every light and nobody wants to get on or off the bus.) I find the distance to be more accurate than the time for routes in progress. Regardless, it’s close and clearly worth heading to the bus stop.

The next bus is about 30 minutes later and the scheduled to depart terminal time is right at 2:30. The depart terminal for the next one is also right at 3pm. However, if you’ve mastered elementary school math, you might notice that a bus that leaves 30 minutes later is not arriving 3 minutes later (35-32).

The distance away is also interesting. The whole route is a little over 7 miles. And neither bus has left the terminals. Puzzling me where the number of miles away came from.

2025 attempt to buy us open tickets

Last year was the first year it was hard to buy US Open tickets. In 2023 and earlier, I would buy them after work during the American Presale, no problem. Ok fine, it’s going to be like Comic-Con where you have to buy them the second they become available. Here’s how that went.

Tuesday – American Express Presale

Sales start at 9am. I was on the site before that. Everyone on the site gets a random number. Mine was 3200. The number went down slowly to about 2200 (over about 40 minutes) and then flew down to zero. When I got in, I was able to see Grounds Passes for the day I wanted. I attempted to put it in my cart and it said they were no longer available. I repeated this a few times and then it stopped saying available at all.

I then went to buy my Ashe ticket for a different day. I made the mistake of using a different browser tab so back in the queue. (You can’t use multiple devices or multiple tabs.) It took less time to get to the front of the queue this time and I was a able to get a ticket. A big change this year is they just tell you the row number and not the seat number. Which is annoying because I want to be within a few seats of the aisle and not some random place in the row. After I paid, I got my actual seat number which turns out to be an aisle.

I paid with my american express card and was not prompted for a one time pass code texted to my cell. (This is important; remember this)

Friday – Public sale

I know they don’t release all the tickets during the presale so I tried again. I was on the Ticketmaster site before 9am. This time, I got number 19 in queue. Awesome. There were plenty of grounds passes for the day I wanted. (And plenty of resellers charging double price.) I put three official tickets in my card for myself and my friends. Great. I didn’t get that far on Tuesday.

I then went to pay. Where I get prompted for a one time PIN that “was texted to me.” It was not. I tried clicking resend a few times. No text. Unfortunately I didn’t have another credit card with me. Then my session timed out. I tried again (at 9:15am) and all the non-resale grounds passes were gone.

The future

The US Open did release more grounds passes closer to the time last year. But you have to keep checking to see when which is annoying. Also last year, they didn’t sell grounds passes in person. You have to buy them online.