Dave Boster

How Fascinating! \(๏◡๏)/

Healthcare, technology, and lessons yet to be learned

In a deviation from my normal commute routine, the FM radio was on, and broadcasting the story “An electronic health records system for veterans has caused unnecessary suffering” (npr.org, 2023).

It took decades for the VA to begin updating its electronic health records system. After breakdowns, the VA stopped all work on the $16 billion update with the Oracle-Cerner electronic health record.”

In a four-minute listen, the story covers:

  • a decade-long wait for an electronic health records system upgrade
  • a ten-year, no-bid, ten-billion-dollar contract
  • a limited rollout with critical breakdowns and gaps
  • catastrophic consequences for veterans

The Veterans Affairs (VA) department press release, “VA Signs Contract with Cerner for an Electronic Health Record System”, announced the contract in May 2018. The very first statement of the news release blatantly violates advice from an early mentor: “Underpromise and over-deliver”.

“I am pleased to announce we have signed a contract with Cerner today that will modernize the VA’s health care IT system and help provide seamless care to Veterans as they transition from military service to Veteran status, and when they choose to use community care.”

(digital.va.gov, 2018)

On digital.va.gov, the “more stories” section from the original press release offers a view into the timeline of the project. The VA news releases site offers a more complete view.

During the broadcast, a soundbite was played from Senator Patty Murray on the situation:

“I’ve heard from providers who are burnt out trying to navigate this broken interface, patients who were unable to get medicine they rely on because of system malfunctions and even a patient who received a late cancer diagnosis because of flaws in the system. And that’s just what we know right now. It is unacceptable.”

That statement should make any leader, developer, or participant in software development projects pause.

It’s a cautionary tale, maybe even an anti-pattern, but it’s also a great opportunity to spark discussion, learning, and practice HugOps. Practicing external post-mortem analysis, discussions on bias, searching for “bright spots”, and correlating to other similar situations.

There’s a similar tale almost a decade before this with the situation around software development practices and the creation of the US Healthcare.gov website.

Don’t Go Chasing Waterfalls

I couldn’t resist a throwback to the 90’s musical group, TLC. 😉

It comes from the article Don’t Go Chasing Waterfalls: A More Agile Healthcare.gov (newyorker.com, 2013) which gives some background into the US Healthcare.gov situation.

It also offers a historical review of large software systems dating back to the 1970s, particularly with Winston Royce and his description of waterfall development in his paper “Managing the Development of Large Software Systems” (Royce, 1970).

Royce lists seven steps for software development:

  • begin with a full description of what the software needs to do,
  • create detailed specifications,
  • analyze these specifications,
  • create a program design,
  • write the code,
  • test it,
  • and operate it.

(newyorker.com, 2013)

I once heard Uncle Bob (Robert C. Martin) talk about the misinterpretation of Royce’s paper, which led to what we know as the current waterfall development model. The article highlights this as wwell:

He goes on to predict the fate of many projects that would eventually use this development model, writing that, if testing fails, “the required design changes are likely to be so disruptive that … the development process has returned to the origin and one can expect up to a 100-percent overrun in schedule and/or costs.”

(newyorker.com, 2013)

The takeaway isn’t to focus on Royce or the waterfall development model, but to talk about the lessons learned from the US Healthcare.gov situation.

If the first testing of the complete system occurred in the last two weeks of September, then Healthcare.gov was only halfway through what Royce would have described as a complete waterfall development process. The experience for millions of Americans in the weeks since, predictably, has not been good.

(newyorker.com, 2013)

This wasn’t the first nor the last in very expensive, very painful, and very public, cautionary tales about the dangers inherent with large software projects.

What is it true of?

After thinking about both situations, I’m reminded of what Michael Lewis said about Daniel Kahneman in one of my favorite books “The Undoing Project” (Lewis, 2016).

Later, when he was a university professor, Danny would tell students, “When someone says something, don’t ask yourself if it is true. Ask what it might be true of.”

That was his intellectual instinct, his natural first step to the mental hoop: to take whatever someone had just said to him and try not to tear it down but to make sense of it.

An excerpt from: The Undoing Project: A Friendship That Changed Our Minds (Lewis, 2016).

I’m interested to think more about both of these projects in this light. To dive deeper, discuss with others, and see if there’s something more to these stories and countless others like them, both publicly and within our own organizational walled gardens.

I wonder… is something profound happening where healthcare, government, and technology intersect, to prevent us from learning, understanding, and then adapting to not repeat the same mistakes? Does this unseen force reach past the intersection of these spaces, past these sectors entirely, to something greater or more fundamental?

Hi, I'm Dave, nice to meet you!

I’m a crazy individual who loves to spend time with my family, leverage technology to help others, try some impossible things, and then see how much I can fit in 24 hours.

In the process of evaluating GitHub Pages, I’m testing out the Jekyll Posts to see if these will help save brain cycles thinking about structure and layout. Instead, I want to find ways for users to focus on content.

To complete this MVP, here’s some information from my first page that I’d like to include to see some additional content in a post. This might make it more likely for me to update and evolve main page.

Hello Mr. Turek, I am here!

This is my version of “Hello World”, a line used by many programmers when getting started. Dan Turek taught Math and Computer Science at Burke High School and through some small, but impactful moments, helped shape my path in programming and technology.

The MVP of Personal Websites

My vision for this site is to create a resource to help me process my thoughts and possibly help others.

I hope to explore the use of GitHub Pages as an effective tool for Software Developers to advocate for their public identity, to offer a tool to assist them with introspection, and to promote continual learning through an employer-agnostic repository of information.

In the process of doing all of this, I’d like to improve my communication skills through the disciplined writing and management of a public website tied to my name. 😬

Getting to know GitHub Pages

I’ve decided to investigate GitHub Websites in search of a method to work on communication and reflection. Writing journal entries is useful, however, I will usually end up using these as a dumping ground for links, thoughts, and pictures. Just by publishing these I will need to find a balance between efficiency and clarity.

Though this attempt, I am hoping to accomplish the following objectives, in order of importance:

  1. Improve my communication skills by learning how to use written words to most efficiently describe:
    • Problem
    • Insight into my thought process
    • Result
  2. Reflect on lessons learned
  3. Explore the use of GitHub Pages as an effective tool for Software Developers to communicate who they are and to offer a tool to assist them with introspection and continual learning.

Beginning the Journey

I want to immediately just get started and it was painful to write out the “what” and “why” for this first entry. I am pretty sure it was always in my head, but it took a concerted effort to pull it out, clean it off, and putting it to text.

About GitHub Pages

To get started, I’m using the GitHub Pages QuickStart. After skimming the first section of the QuickStart, I’m ready to get started.

After the first few steps and about ten clicks, here’s what I have found:

  • A pages repository setup, but without any content
  • Encryption (HTTPS/SSL) is not enforced by default
  • There is no 3-click wizard to get me up and running

GitHub Pages Take 1

After a bit more patience and completing the “Creating your website” section of the QuickStart, I have a nice looking website.

GitHub Pages Take 2

Now comes the hard part… what do I want to add for content? My first hour on this project has flown by, so content will need to be the topic for another day.

Shoutout to GitHub. I have to admit I did not expect to have a working website with a fitting design and color scheme within the first hour.

Result

I have a web presence! The best feature is that anyone can get their information on the nets without having to sign-up for hosting plans, configure cloud infrastructure or complex pipelines.

It’s been a while since I’ve been able to do a “hello world” type of project. It feels good to try something new and give a salute to an old friend an mentor, Mr. Daniel Turek!

Lessons Learned

  • GitHub Sites offers a good selection of quality themes to use out of the box.
  • Markdown is a much nicer experience than a text editor and HTML I remember from the 1990’s.
  • Sites allow you to focus effort on content (what/why) and not the technology (how).

Next Steps and Thoughts

  • Explore ways to manage content on this site, such as a blog, biography, etc.
  • Integrating with other tools and markdown editors to support different flows and preferences.
  • Can I get this first post on my new GitHub Site?
[ ]