Uncharted Waters


July 12, 2018  10:00 AM

The Magic Automation Tool

Matt Heusser Matt Heusser Profile: Matt Heusser
automatic, Automation

An Automation ToolTake any part of the development process – say testing, my bread and butter. Your team has it all figured out, with a magic automation tool. By magic, I mean exactly that. Push a button and you will get instant test results, clearly articulated.Not fast — instant. I’m talking about magic.

The automation tool never makes a mistake. It magically knows what a change will be and how it should impact the system, so it never reports a false error when the system behavior changes. Because of this, it needs no maintenance. Just change the code, click the button, see all the problems.

Now, will having that accelerate your software delivery at all?

In many cases, the answer is “no.” Even with the organizations that benefit, the benefit might only be a two to four percent increase in throughput.

Here’s why, and how to do better.

Continued »

July 6, 2018  3:10 PM

The Internet of Things Meets Usability

Matt Heusser Matt Heusser Profile: Matt Heusser
Internet of Things, iot

Usability and the Internet of ThingsPrior to the release of the Nest Thermostat in 2011, the Internet of Things was mostly hype. Refrigerators that texted you when milk spoiled were not really possible. Lawnmowers that texted you they had not been used in awhile were less useful than, say, looking at the grass.

Today, internet of things devices are real, and valuable.

The only problem is getting them to work.

Continued »


June 28, 2018  10:34 PM

Beyond Ugly Code

Matt Heusser Matt Heusser Profile: Matt Heusser
Programming

Ugly Code Imagined as a structureTen years ago, I was asked to code review an application. The code was the ugliest I had ever seen – by far. The code was so bad that I could see bugs by looking at it.

Hard-coded test directories on the server.

Hard-coded test databases in the code.

Exception handling that couldn’t actually handle the exception at the level it was called for.

I reported the errors to my management, and they replied that I did not understand the code review process. It was not my job to give an up-or-down vote, but instead to review the code. The code review had occurred, therefore I needed to check the box for code review and move the code into production. If it were ugly or not was merely a matter of my opinion.

If only I had known what to say — that ugly code is bad code. Code so complex I cannot understand what is happening.

Code that bad will have errors that we cannot even find, because we cannot figure out what the code is doing.

How does code become ugly?

One change at a time.

Let’s talk about that.

Continued »


June 26, 2018  9:01 PM

Building a Lead

Justin Rohrman Justin Rohrman Profile: Justin Rohrman

The path to leadership in software usually looks something like this. A junior programmer takes a job out of college and works diligently. Every couple of years, that person hops to a new company to get a new job title and an accompanying raise. Eventually, they find a place to settle in for a while. They work into the senior role, get antsy for what ever is next, and poof, they are given a promotion and become a newly minted ‘lead’.

In that time, our developer friend learned to become competent at their trade (hopefully), became familiar with a couple of code bases, and probably has a reasonable professional network. But, where does the leadership come in?

Continued »


June 25, 2018  11:18 PM

To Spike or to Build, That is The Question

Justin Rohrman Justin Rohrman Profile: Justin Rohrman

Somehow, sometime, the concept of a spike got introduced into agile practice and language. The general idea is this; we need to make a product change but aren’t quite sure what direction to take or how to find that direction in the first place. A spike is the black flag we raise to say we need time to work on something that isn’t _obviously_ productive. The end result should be information and a general idea of what we need to do next, not code and software in production.

The rules are simple, the implementation is not. What I usually see, is spikes that result in a day of reading API documentation. So, the question then, is when is it a good idea to spike something out and when might we be better served by digging into the work and learning from that experience?

Continued »


June 20, 2018  11:33 PM

Considering Cyclomatic Complexity

Matt Heusser Matt Heusser Profile: Matt Heusser
Code Complexity, Complexity

The cyclomatic complexity of a train stationThe longer the function, the more complex it is, the more likely we are to make mistakes. Knowing that makes measuring code complexity, and making the complexity of functions smaller, seems like a very good idea.

So how do we measure it? The most common measure of code complexity is probably “cyclomatic complexity.”

So what exactly is “cyclomatic complexity?”

The definition both confuses me and puts me to sleep at the same time – and I’m a formally trained mathematician with coursework in graph theory.

Seriously, try to make sense of this. You can just skim; I’m going to give an explanation in English later:

The formula of the cyclomatic complexity of a function is based on a graph representation of its code. Once this is produced, it is simply:

M = E – N + 2

E is the number of edges of the graph, N is the number of nodes and M is McCabe’s complexity.

To compute a graph representation of code, we can simply disassemble its assembly code and create a graph following the rules:

 

  • Create one node per instruction.
  • Connect a node to each node which is potentially the next instruction.
  • One exception: for a recursive call or function call, it is necessary to consider it as a normal sequential instruction. If we don’t do that, we would analyze the complexity of a function and all its called subroutines.

That’s crazy.

Here’s the Matt Heusser GoodEnough™ explanation of complexity, why it matters, and how sometimes, it doesn’t.

Continued »


June 11, 2018  11:27 AM

How did Elizabeth Holmes do it?

Matt Heusser Matt Heusser Profile: Matt Heusser
Fraud, HR, quality

Elizabeth Holmes in Inc MagazineThe October 2015 cover of Inc. Magazine featured Elizabeth Holmes, the pioneering CEO of Theranos. Holmes had discovered a way to take a hundred-plus blood tests in one – in a fraction of the time, from the prick of a finger instead of a vial-per-test. The technology even had the potential for home use, more like a at-home pregnancy kit than the wait-two-weeks lab tests that are the current state of the practice.

The only problem is that it wasn’t real.

None of it.

On her warpath to home-testing, Holmes raised 1.3 Billion in investment funds.

How did that happen? Continued »


May 31, 2018  3:12 PM

Machine Learning As True AI? Not Yet

Matt Heusser Matt Heusser Profile: Matt Heusser
Artificial intelligence, Machine learning

Book Of Why: Machine LearningAccording to Judea Pearl, a co-creator of the Bayesian Filter, today’s machine learning is just “curve-fitting.” That’s taking a set of data points and mapping it into a line. This can be incredibly effective at, say, predicting seasonally-adjusted demand in order to reduce excess inventory yet keeping the shelves fully stocked.

But is that really artificial intelligence?

Pearl says no, and that the applications for that kind of specific, directed Machine Learning are less than the you might think.  Continued »


May 29, 2018  10:06 PM

Should Employers Expect Honesty?

Justin Rohrman Justin Rohrman Profile: Justin Rohrman

This story about mistrust was circling around one of the technology themed Slack groups I watch. The plot line is that a manager has an employee abruptly put in notice. She is upset about having a top team member leave, but also because she feels this person is not telling the full truth about why he is leaving. The story reads like an ‘Ask the editor’ type of column you might find in your local news paper. Not the paper for the city you live in, but maybe the town or neighborhood.

Someone in the Slack thread asked “Is anyone completely truthful with their employer”? The overwhelming answer was of course not. I am no because my situation is different. But, when I was employed by a company, and if I am ever again in the future, I’d be a ‘no’ too.

Here’s a little story about a time I put in notice to explain why I have always kept things back from employers.

Continued »


May 23, 2018  12:24 PM

Reducing Stress from Work

Matt Heusser Matt Heusser Profile: Matt Heusser
control, power, Stress

Stress BallImagine for a moment that you step into a therapists office, complaining of stress. You ask what to do and the therapist asks you for your ideas. You suggest running, watching a ball game, taking a nap, having a few beverage with friends, talking a walk, or watching TV. The therapist replies “It sounds like you have some good ideas.”

Today I’m going to talk about a totally different way to manage stress. Continued »


Forgot Password

No problem! Submit your e-mail address below. We'll send you an e-mail containing your password.

Your password has been sent to: