Cognitive subroutines

This is going to be a relatively long post, mostly inspired by reading Blink, by Malcolm Gladwell, and Sources of Power, by Gary Klein, both books that explain how and why our unconscious decision-making capabilities are often better than our conscious ones, and also explain when such capabilities fail and need to be over-ridden.

I was sitting there thinking about these issues last week while sitting on stage during our concert of Schumann’s Das Paradies und Die Peri. We have a section in the middle of the concert where we sit for about 45 pages with only a couple pages of singing in the middle to keep us awake. So for four nights in a row, I had plenty of time to sit and think. And on Friday night, I had one of those moments where I connected a bunch of ideas, and synapses lit up, and I found a story that really works for me explaining some of this stuff. I was actually sitting there in the concert trying to figure out if I could get out my Sidekick and send myself a reminder so that I wouldn’t forget the synthesis, but I couldn’t. Fortunately, the idea was strong enough that I jotted down the basic outlines when I got home. This is all probably pretty obvious stuff, but it put things together in a way that made a lot of sense to me, bringing together a bunch of different ideas. So I’m going to try to lay things out here.

The basic idea builds off of Klein’s idea of expertise getting built into our unconscious. Our brain finds ways of connecting synapses that leverage our previous experience. Why does it do that? I’m going to assume that it’s a result of the constraint stated in The User Illusion, that consciousness operates at only 20 bits per second. The information processing power of our conscious mind is very low, so our unconscious mind has to find ways of compensating for it.

Here’s the basic analogy/story that I came up with, being the programmer that I am. When I’m writing code, I often notice when I need to do the same task over and over again. As any programmer knows, when you’re doing something over and over again, you should encapsulate that repeated code into a subroutine so that it doesn’t need to be copy-and-pasted all over the place. I would imagine that a self-learning neural network like our brain does a similar task. So far, so obvious.

This relates pretty well to my own experience as a learning machine. When I’m learning a new game, for instance, my brain is often working overtime, trying to figure out how the rules apply in any given situation, going through the rules consciously one by one to figure out what the right move should be. As I play the game more and more, I learn to recognize certain patterns of play so that I don’t have to think any more, I just react to the situation as it’s presented. This is what Klein describes as Recognition-Primed Decision Making. To take a concrete example, when I was first learning bridge, the number of bidding conventions seemed overwhelming. I had this whole cheat sheet written out to which I continually referred, and every bid took me a while to figure out. As I played more and more, I learned how each hand fit into the system, so that I could glance at my hand and know the various ways in which the bidding tree could play out. As Klein describes it, my expertise allowed me to focus on the truly relevant information, discarding the rest, allowing me to radically speed up my decision making time.

Back to my story. Thinking about wiring our unconscious information processing architecture as a bunch of subroutines leads to a couple obvious conclusions. For one, it’s easy to imagine how we build subroutines on top of subroutines. A great example is how we learn a new complicated athletic action. It also applies on the input side.

Another obvious result is that because subroutines are easy to use cognitive shortcuts, they may occasionally be used inappropriately. What happens when a subroutine doesn’t quite fit what it’s being used for? Well, in my life as a programmer, I often try to use that subroutine anyway. It doesn’t end up giving me quite what I want, so I find a way to kludge it. I’ll use the same subroutine, because I don’t want to change it and mess up the other places that it’s called, but I’ll tack on some ugly stuff before it and after it to compensate for the ways in which it doesn’t quite do what I want.

How does this relate to our brains? I think a prejudice is essentially the same as a cognitive subroutine. It does a bunch of processing, simplifies the world down to a few bits, and spits out a simple answer. And, in most cases, the subroutine does its job, spitting out the right answer; it wouldn’t have been codified into a subroutine if it didn’t. Much as we may not want to admit it, prejudices exist for a reason. However, when we start to blindly apply our prejudices, using these canned subroutines without thinking about whether it’s being applied under the appropriate conditions, then we get into trouble. Gladwell calls this the Warren Harding error.

What is the right thing to do? Well, in programming, the answer is to think about how the subroutine is used, pull out the truly general bits and encapsulate them into a general subroutine, and then create specific child subroutines off of that, assuming we’re in an object-oriented environment. In general when using a subroutine, certain assumptions are made about what information is fed into the subroutine, and what the results of the subroutine will be used for. If those assumptions are violated, the results are unpredictable. A more experienced programmer will put in all sorts of error checking at the beginning of each subroutine to ensure that all the assumptions being made by the subroutine are met.

How does this apply to the cognitive case? I think this is a case where it gets back to my old post about questioning the assumptions. If we try to understand our brain, and understand our kneejerk reactions, we will be in a much better position to leverage those unconscious subroutines rather than letting ourselves be ruled by them; our intelligence should guide our use of the cognitive shortcuts and not vice versa.

This idea of cognitive subroutines also gives me some insight into how to design better software. I picture this cognitive subroutine meta-engine that tracks what subroutines are called, and strengthens the connections between those that are often called in conjunction or in sequence, to make it easier to string those routines together, eventually constructing a superroutine that encompasses those subroutines. It seems like complex problem-solving or pattern recognition software should be designed to have a similar form of operation, where the user is provided with some basic tools, and then the software observes how those tools are used together, and constructs super-tools based on the user’s sequence of using the primitive tools (alert readers will note that this is the same tactic I propose for social software). I’m somewhat basing this on a book I’m reading at work called Interaction Design for Complex Problem Solving, by Barbara Mirel, where she discusses the importance of getting the workflow right, which can only be done by studying how the users are actually navigating through their complex problem space.

So there you go. Treating the brain as a self-organizing set of inheritable subroutines. I’m sure this is obvious stuff. Minsky’s Society of Mind probably says this, but I’ve never read it. Jeff Hawkins’s book On Intelligence probably says something similar as well (I should probably read it). And I suspect that Mind Hacks is in the same space. So it may be obvious. But, hey, it’s new to me. And it just makes a lot of sense to me right now, in terms of how I learn to do new complex activities, and how it relates to my work as a programmer. I’ll have to think some more about if this can actually be applied in any useful manner to what I do. And about the shortcomings of the theory.

P.S. Tomorrow we’ll get back to more light hearted subjects, like why I think the TV series Firefly failed, with a compare and contrast to what Joss did right in Buffy.


new complicated athletic action: When learning a new action, we break the action down into individual components and practice them separately. When I was learning how to spike a volleyball, the teacher had us first work on the footwork of the approach. Left, right, left. Left, right, left. We did that a bunch of times, until it became ingrained into muscle memory. Then we practiced the arm motion: pulling both arms behind our back, bring them forward again, left arm up and pointed forward, right arm back behind the head, then snapping the right arm forward. Then we coordinated the arms with the footwork. Once the entire motion was solid and could be performed unconsciously, then we threw a ball into the mix. That had to come last because the conscious mind is needed to track the ball and coordinate everything else to make the hand hit the ball in the air for the spike. Only if everything else is automatic do we have the processing power to make it happen. If we had to think about what steps we needed to take, or how to move our arms, we would never be able to react in time to get off the ground to hit the ball. It’s only because it’s been shoved into our unconscious that we can manage it.

Another recent sports example for me is ultimate frisbee. I’ve been working on my forehand throw for the last year or so. After several months, I finally got it to the point where I could throw it relatively reliably while warming up. However, as soon as I got in the game, I would immediately throw the disc into the ground or miss the receiver entirely. It was incredibly frustrating because it demonstrated that I could only throw the disc when I was concentrating on the mechanics of how to throw the disc. As soon as I was thinking about where I wanted to throw the disc, or how to lead the receiver, the mechanics went away, and the throw failed. This last tournament I played, though, the muscle memory of the throw had apparently finally settled in, so when I saw a receiver open, I thought “Throw it there”, and the disc went there. The relevant neural infrastructure had finally been installed, so that I could concentrate on the game, and not on the throw, and it was incredibly satisfying. I threw three or four scores, which was more than I ever had before, and only threw it away once the entire day, ironically on a play where I had too much time to think, so that the conscious machinery kicked back into play rather than letting the unconscious muscle memory do its thing.


input side: I guess the analogue on the input side would again be game play recognition. A beginning chess player will have to laboriously trace out where each piece can move and can maybe see the results of a single move. An intermediate chess player will recognize how to handle certain subsections of the board, and be able to project out a few moves. The expert chess player will instantly take in the position of the whole board, and understand how the game will develop as a whole. And this is definitely a cognitive shortcut born of repeated experience. This study demonstrates that chess masters perform vastly better than novices at being able to recognize and remember valid board configurations, but were no better than novices at recognizing invalid boards. In other words, because the novice perceives the board as a collection of individual pieces, they can not tell the difference between a valid and invalid board. Meanwhile, the expert, because they perceive the board as meaningful chunks of board positions, can rapidly grasp the game situation of a valid board, but the invalid board looks like nonsense, demonstrating that their brain is using its expertise as a cognitive shortcut.

More generally, when confronted with a complex situation, an expert can pay attention to the key experiential data and ignore the rest. Gary Klein describes how an expert always has a mental model to which he is comparing the situation, a story if you will, that describes what should be happening. When what actually happens differs from what he expects to happen, the expert knows something is wrong, and re-evaluates the situation, as Klein illustrated with several anecdotes from firefighters. And part of that model is being aware of when things _don’t_ happen as expected. And it may not be a conscious model; in fact, Klein describes many instances where the firefighters attributed their decisions to a sixth sense or ESP. But it is a model born of experience; the unconscious brain has experienced the situation over and over again until it knows how certain factors will affect the outcome (Klein calls these factors “leverage points”).

18 thoughts on “Cognitive subroutines

  1. Hi Eric. I googled ‘subroutines of the brain,’ and you are what comes up, so I thought I’d chat. I’ve described a subroutine that I believe I am afflicted with, that I call ’empty a hand.’ I trust, as you suggest above, that no end of stuff that brains do is self-organizing subroutines, but I don’t know a lot about that. I just know that ’empty a had’ serves me poorly, which is doubtless why I’ve noticed so much about it.

    Basically, ’empty a hand’ seems to be called when I’m doing something, I’m currently holding something, and I need to do something else with that hand. My brain hands control to this subroutine to quickly get rid of the unwanted item. My conscious mind thus doesn’t loose lock on the task at hand. But the subroutine has…limitations.

    First, the subroutine knows nothing of the history or future utility of the thing in the hand. So it makes no attempt to find a ‘good’ place for it. It’s main concern is to find a ‘safe’ place for it, that is, a place not likely to result in immediate trouble from the thing falling or being kicked or trampled. So any large-enough flat place will do, and more up-out-of-the-way is better. Since the nature of the place and the thing are not really considered, it often picks ‘safe’ places my conscious mind would never consider, eg, a just-removed screw on top of the canned-goods–in back. But that’s not the worst part.

    The worst part is ‘Empty A Hand’ absolutely contains no code to put anything in memory! Indeed, the last thing it does is flush all records of its operation. Once the subroutine has gotten rid of a thing, where it went is utterly forgotten. Only a search will find it again. And if the safe place it found was quite safe, the search may be a long one.

    I’d love to edit this code, but don’t know how….

    1. Hi Don, thanks for the comment!

      The only way I know of to “edit the code” is to build new habits. To build new habits, though, you first have to be aware of what you’re already doing – you have to be mindful in the moment to notice that you are running what you call the “Empty A Hand” subroutine.

      I’ve been working on getting more mindful in my own life for such things e.g. I have a tendency to say stupid things that are just expressing my own insecurities. And first I would look back at the conversation a few hours later, and realize I said something stupid. And then I got better at noticing, and noticed a few minutes later. And then I got better at noticing, and noticed as I was saying it and could take it back. And now I’m getting better at noticing I’m about to say something, and can edit it before I say it.

      So in your case, I might suggest trying to be more mindful of when you “Empty A Hand”. And then once you are noticing when you are running the “Empty A Hand” routine, then you can start figuring out a more systematic method of where you want to put things, and start doing that. As you do that more and more, the “code” will be edited to put things away according to your more systematic method. I have my own routines of where to put things which are now automatic, so I don’t have to think about it e.g. when I’m staying someplace that’s not home, I keep everything in one place, so that it’s easy to see everything when packing up and I’m less likely to leave something behind.

      Good luck! Let me know what happens!

Leave a Reply

Your email address will not be published. Required fields are marked *