Crystal Ball Gazing

It used to be that there was a fundamental difference between Macintosh computers and PCs. I could give you the list of items but then if you are reading this, you probably already know what I’m talking about. I make no bones about being a fan of the Macintosh. I have also used various versions of Windows for almost thirty years. Not to mention all of the other operating systems along the way. I feel particularly qualified to say, the operating system wars are over.

Who won? We all did. Why is there still more than one operating system? Why are there more than one kind of car? People have different preferences. Most often it boils down to what they are familiar with. In my case, I am equally familiar with Windows, macOS, and Linux so it boils down to taste and habit. I think that the continued existence of multiple operating systems is essential to the continued evolution and improvement of all operating systems.

What is in the future of operating systems? That is impossible to say with any authority. It all depends on the imagination of the developers that write those systems. I do think I can identify some trends though.

Operating systems will evolve so that they fade into the background of the workflow. Take for instance the move toward so called cloud computing. Someone I work with once quipped “Cloud computing is just doing your work with someone else’s computer.” The point that he was missing was that you are doing your work without having to worry about what computer you were using. If you needed to access data on a central server, it felt the same to you as accessing data on your local machine. If you needed to enlist a bunch of processor cores to solve a problem with lots of independent data, the cloud can arrange for the resources without you having to worry about any of the details except paying the bill.

Opera recently announced an experimental browser called Neon that uses a paradigm of a desktop in the browser. Favorite URLs are represented by icons on the “browser-top” and different open tabs can be viewed in split screen mode or collapsed to icons along the side of the screen. These are interesting variations on the operational scenario of web browsing. This is particularly interesting considering the recent proliferation of web applications that run in the browser instead of on the native operating system.

So the days of “my operating system is better than your operating system” are over except for the inevitable arguments in junior high school lunch rooms. Adults have largely come to realize that it is a matter of choice and there really isn’t any compelling reason to prefer one operating system over another on a strictly objective basis.


Sweet dreams, don’t forget to tell the ones you love that you love them, and most important of all, be kind.

Downtown Writer’s Group Meeting

Tonight was the inaugural meeting of the Huntsville/Madison County Public Library Downtown Writer’s Group.  There were nine people in attendance. We discussed what we expected to get out of the meetings and heard about the planned program for out next meeting. We outlined some ground rules for the critique sessions. Then we sat around and talked informally. It was exhilarating to meet and take with people that had similar interests to me.

I first heard about this group at the “Thank Goodness It’s Over” luncheon that was held by the regional volunteers of the NaNoWriMo organization. The library had hosted “write ins” where participants in NaNoWriMo could come and work on their novels and hang out with other writers. I didn’t make it to any of the write ins but I did make it to the luncheon.

One of the perks of the luncheon was some free books that were donated to the group. Everyone got one and the book that I got was entitled “Imager” by L. E. Modesitt, Jr. It turned out to be a well written fantasy novel. It takes place in a school for wizards and was set in a world that reminded me of nineteenth century Italy with a well thought out system of magic that revolves around the wizard’s ability to manifest matter from matter in the environment through sheer force of will. I plan to read the rest of the novels in the series.

I also heard about several online resources that I hadn’t come across before. One of them, Scribophile, is a source of online support for writers. You read and critique other’s works to earn karma points that can be spent to upload your own works for others to critique.

I am excited about participating in the group. I’m also excited to have met some like minded people. It was a fantastic ending to a rather hectic day.


Sweet dreams, don’t forget to tell the ones you love that you love them, and most important of all, be kind.

Epistemology? We Don’t Need No Stinking Epistemology!

What is thought? We don’t really know. There are a lot of theories. There are a lot of assumptions. For instance, we assume that what we perceive with our senses have some grounding in an objective reality outside of ourselves. Further, we assume that there are other people, besides ourselves, that perceive the same objective reality with their senses.

But how does a network of electro-chemical reactions somehow emerge as the complex process that we label thinking. We can’t even agree upon what constitutes the base criteria for judging a process rational thought. In the past we chauvinistically maintained that only humans were capable of rational thought.

Recent experiments with animals from whales, through various primates, studies of dogs and cats, and even crows have demonstrated mental abilities that were once claimed as evidence of conscious intelligence and the exclusive domain of humans.

Alan Turing posed the functional test for intelligence. A person interrogates an entity through an electronic connection and asks them any questions that he likes. He then guesses whether he is talking with a person or a program solely on the basis of their answers. If the program consistently fools the interrogator, it is judged intelligent. By that measure, we have already produced programs that can pass the test.

And yet we still have no clear definition of intelligence and the program that occasionally passes the Turing test is only nominally intelligent. The lack of depth of its so called intelligence is eventually exposed.

So why am I asking these questions? I am trying to figure out why when I try to think, I just get frustrated but when I relax and go with the flow I write coherent, if not brilliant, blog posts. Is it a universal admonition to be here now? Is it evidence of something larger than ourselves? Or is it just a statistical expression of the fundamental laws of physics amortized over millennia of combination and recombination?

I guess I’ll climb out of my navel now. I really am interested in the answers to these questions. I’m not just asking them to seem like I think deep thoughts or anything like that. I think that coming to terms with some of the ramifications of such questions and their possible answers is part and parcel to becoming a good writer.


Sweet dreams, don’t forget to tell the ones you love that you love them, and most important of all, be kind.

Epiphany: Types are Orthogonal to Functional Dispatch

Most people are most eloquent in their native tongue and the same seems to be true of programming languages. There are those polyglots that excel at any language they learn but it is often more true than funny what they say about  a good Fortran programmer being able to write Fortran in any language. Only in my case I would have to substitute C for Fortran.

Many years of study and coding in Java, Ruby, Python, Lisp, and various other languages has softened my C accent but it is there for those that know to look for it.

I think it can also be said that the first language in which you encounter a particular paradigm colors your attitude toward that paradigm. For instance, I first learned about object oriented programming in Java. Soon after I encountered it in CLOS, the object extension to Common Lisp. I struggled mightily to understand CLOS. Now, some thirty years later I have realized why I had problems understanding it.

Java, like most of the strongly typed, statically compiled languages, tries to constrain functions that operate upon an object to be encapsulated in it’s class. CLOS, on the other hand, considered classes to be an extension of data types. Methods, with their type driven dispatch, were independent from classes.

Eventually, I grasped how methods worked in Lisp. It was a long time until I was comfortable with it though and I still catch myself falling back into conflating types with method encapsulation.

So, I was thrilled to discover that Julia followed the CLOS model of specifying data hierarchy with object types and letting method dispatch be orthogonal to them. There is much to be learned from such an elegantly designed language.

I obsess like this with each new programming language that incorporates what we have learned about expressing ourselves about data and functions in ever more eloquent fashions. It is part and parcel of my infatuation with programming languages. In that, I hope you will indulge me.


Sweet dreams, don’t forget to tell the ones you love that you love them, and most important of all, be kind.

Placebos Are Effective More Often Than Not

Watching a show on the placebo effect on the BBC tonight I realized that the power of the mind to control the chemistry of the body is far more profound than conventional western science would expect. In case after case, the show described studies where patients had profoundly positive results with only placebos and caring treatment from their physician. In some cases, the patients were told they were receiving placebos and yet they still experienced positive results.

The show described one study where a surgeon studied the results of conducting a placebo procedure instead of a very effective surgical treatment. In one of the cases presented, the patient had received the actual procedure for a previous injury so she knew what the real procedure felt like and yet she had positive results from the placebo procedure.

The show went on to explore the practice of medical hypnosis and studies that focused on the impact of positive suggestions from the physician in the case where all patients received placebo acupuncture. It became clear that the operative factor was the caring attention and confidence of the physician.

I have studied meditation and the western mystery tradition. I believe that the effectiveness of these so called magical traditions are closely akin to that of the placebo effect and the key thing to understand here is that the placebo effect is real. The results, while not universal or in all cases permanent, are verifiable with conventional, repeatable scientific studies. This indicates to me that we have only studied the tip of the iceberg when it comes to the power of the mind over matter, in particular the body.


Sweet dreams, don’t forget to tell the ones you love that you love them, and most important of all, be kind.

First Thoughts on Julia

I’ve been coding the Countdown Numbers game that we designed several days ago in the Julia language this afternoon and evening. So far, I’ve implemented the number selection and target selection functions. I’m currently working on the code that generates potential solutions and evaluates them using the criteria established in the definition of the game.

I am using the Juno development environment. It is developed as a plugin for the Atom editor. So far the only criticism I have of it is that it is a little overly aggressive with suggestions for autocompletion. There is probably a configuration option to tone down the aggression but I was so eager to start coding that I haven’t taken time to read the Juno tutorial.

My first impressions of Julia are very favorable. It seems to adopt the best features of a bunch of the best dynamic languages while managing to avoid feeling like a hodgepodge of features. It is built with the best of current compiler technology and consequently delivers a very performant end product.

Several of its features in particular impress me. First and foremost, it is homoiconic, that is to say, the compiled objects in the language are expressed as data elements of the language and as such lend themselves to dynamic manipulation. This supports the second impressive feature, it supports a full blown, Lisp like macro language. Macros allow you to easily extend the syntax of the language. You don’t need them often but when you do, they can turn writing and maintaining a complex code base into a walk in the park.

It also has full blown multiple dispatch, which is to say, you can have a function that has separate implementations depending on the types of arguments that you pass into it. For example, you might have a function that computes the area of a rectangle. If you passed in parameters of type inches you would be dispatched to a function that computed the area of a rectangle in inches from the height and width of the rectangle in inches. Or, if you passed in one parameter in inches and the other parameter in millimeters, it would be dispatched to another function that converted the parameters in millimeters to inches and then called the original function to compute the area in inches.

Behind most of these features is a type system that helps insure your computations make sense without burdening you with declaring variables, particular when the  compiler can infer what they are from context without your explicit intervention.

The last thing I’ll say tonight about Julia is that the code just looks clean. There is no extraneous boilerplate that tends to clutter up many other languages (cough cough java cough cough).

As promised in the blog post where we designed the Countdown Numbers game, I will walk you through the implementation of it when I get it written. I’ll also discuss why I made tweaks to the design while implementing it.

Go download Julia and have a look at the manual that is available there. It is a good place to start.  If you are impatient, Learn Julia in a few minutes is a good way to get up to speed fast, especially if you have written any Python or Ruby code.


Sweet dreams, don’t forget to tell the ones you love that you love them, and most important of all, be kind.

Musings on Programming Languages

It is interesting to read about programming languages. They are very similar to natural languages in many regards. For instance, you tend to prefer the first language that you learn or, failing that, languages that are similar to it. Some times people try to make excuses along the lines of “I know how to do things in that language.”

The languages grow and evolve over time. Idioms arise and fall into disuse as more expressive ones are found. The best languages encourage evolution through function definition at minimum and often through macro definition and expansion.

Macros have always intrigued me. They are code that rewrites code. They help bring the expression of a solution closer to the form that it was originally conceived in the programmer’s mind.

When I first learned about macros, I was convinced that they were a necessary, if perhaps not sufficient, attribute of a language in which an artificial intelligence would be written. I have since come to believe that artificial intelligence will emerge from the substrate of the protocols and distributed computing facilities of the internet. I still suspect macros will be involved in some way.

What is a macro? It is a piece of code that instead of encoding a solution directly, allows a programmer to specify how one expression of a solution can be transformed to another, often more complex, expression of an equivalent solution. They often take the form of templates that are filled in with arguments inserted from the macro invocation, after which the resulting code is evaluated as it would be if a programmer had written it directly.


Sweet dreams, don’t forget to tell the ones you love that you love them, and most important of all, be kind.

Three Tidbits of Programming Goodness

I’m extremely tired tonight. I am going to mention a few tidbits that I discovered today and then call it a night. I discovered that the Julia programming language had evolved a good bit since I last looked at it. I started reading a tutorial on it and took a quick look at the manual.

Second, I discover the Pony language. I am still investigating what it is but on the surface it appears to be a very pragmatic functional language based on the actor-model paradigm. I’m still getting my head around what that means. It will probably be good for a blog or two when I start to understand it.

I did have a mini-epiphany while I was writing my journal entry this morning. It occurred to me that I didn’t actually need to shuffle the number cards in the Countdown numbers implementation. It is sufficient to pick them randomly and make sure that I don’t pick the same card twice. I figured out that this was a case where modeling the mechanisms that we use to try to insure arbitrariness in our distribution of cards in the real world, i.e. shuffling, was totally extraneous if I was depending on the arbitrariness of a pseudo-random number generator for that in the first place.

I know. I’m tired. I hope that last paragraph made sense. Hopefully I won’t be quite so tired when I write my blog tomorrow.


Sweet dreams, don’t forget to tell the ones you love that you love them, and most important of all, be kind.

Old Programmer, New Idioms

Last night I talked my way through the analysis and design of a program to solve the Countdown numbers game. Tonight I have spent some time attempting to implement this software using Clojure, a modern dialect of Lisp. In doing so, I discovered a blind spot in my programming experience. Clojure is a functional programming language. I’ve spent most of my life writing software in imperative and object oriented languages. I have studied the functional paradigm but I haven’t practiced it to any great extent. Tonight I’m going to discuss what that means and what I will do to move beyond this temporary hurdle.

Functional programming languages are based on the concept of mathematical functions. In pure functional programming languages all data is immutable and functions transform their input into their output with no side effects. That is fine in theory, but the valuable part of most programs, that is reading input from various devices and writing output to other devices for instance, are inherently entangled with side effects. You can’t read a keyboard twice and expect to get the same character unless the user just happens to type the same character twice in a row. To put it simply, the input function depends on the side effect that is the key that the user has pressed on the keyboard.

So, languages like Clojure make clearly defined distinctions between the bulk of the language that honors the functional principles and the non-functional parts of the language that allows practical work to be accomplished. This should be easy to get your mind around but it’s not.

In traditional imperative languages, we deal with variables which serve as containers to store values. We can store a value in the container and retrieve it later and it will still hold the value that we stored in it. In fact, the only way that we can change the value that it holds is to store a different value in the container. Since the container can only hold one value at a time, that clobbers the original value with the new one. This is fine in the case where you have a single processor executing a single instruction at a time.

But in the modern world few computers have a single processor in them and even if there is only one physical processor the software simulates multiple processors and multiple threads of execution. The problem arises when one of those threads stores a value in one of those variables that it shares with another thread, and then another thread decides to read it just as the first thread decides to change it. The results are unpredictable and account for one of the more difficult bugs to find in modern software.

We have been doing this kind of coding for decades now and there are text book solutions to the problem but they are complicated and easy to get wrong and Murphy, the patron saint of programmers, has his way more often than not.

Clojure has made a crucial distinction between values and identities. A value is constant. The number seven has a value that we can count on never to change. Now we might have two containers that can hold a number. The first one we give the identity X and the second we give the identity Y. We assign X the value 7, using a special mechanism that insures that no one will be able to read the contents of X until we have completed writing the value 7 into it.

The key thing to know about the difference between values and identities is that values don’t change and identities don’t actually hold values but rather point to them. Thus, if one thread has a copy of the pointer to the value that an identity was pointing to at one point in time, that value won’t change unpredictably when the identity is changed to point to another value.

This calls for a very different way of programming. You spend most of your time creating temporary values that don’t ever get changed and only rarely give a value a longer lived identity. The idioms of this style of programming are different. I am having to figure them out as I go. I also have to analyze them to decide which ones perform better than others.

In short, you can teach an old dog new tricks but you and the dog have to want to learn and be patient. When I manage to implement this algorithm in Clojure I will devote a blog post or several of them to walking through the solution.


Sweet dreams, don’t forget to tell the ones you love that you love them, and most important of all, be kind.

The Countdown to a Design

This is an analysis and design of a program to allow someone to play the numbers game from the British game show Countdown on a computer. First we’ll review the rules of the game and then we’ll explore techniques for implementing them on a computer.

The numbers game is played with a board of cards containing numbers face down. There are four cards containing either 25, 50, 75, or 100, and twenty cards containing two each of the numbers from 1 to 10. The player specifies six cards to be drawn, between zero and four from the large numbers and the rest drawn from the small numbers. The numbers drawn are revealed and a random number between 0 and 999 is generated. The player then attempts to combine the six numbers using the four arithmetic functions, +, *, -, and /, in order to get as close as possible to the number generated. Ten points are awarded for matching the number exactly, seven points are awarded for an answer between 1 and 5 numbers from the target, and five points are awarded for an answer between 6 and 10 numbers from the target.

The generation of the target is a simple matter since all modern computer languages have a pseudo random number generator which, when combined with some arbitrary parameter such as a portion from the extremely small end of the system clock, provides a truly arbitrary result. For example, if the user were to press the button to generate a target at a time when the nanosecond portion of the system clock contained 345, you might multiply that number by the next pseudo random number returned by the generator and then scale it to be between 0 and 999.

The cards would be handled differently. First, we would declare an array of four big cards and 20 little cards. We would initialize those arrays with the values of the cards that are specified in the rules. Then, we would run an shuffling algorithm, some arbitrary number of times on the big number array, and another arbitrary number of times on the small number array.

The shuffling algorithm would work by generating a pair of distinct random number between zero and three in the case of the big numbers and between zero and nineteen in the case of the little numbers. These numbers would serve as indexes into the respective arrays. For example, you might generate 1 and 3 for the big number array. This would indicate that you should swap the element with an index of 1 with the element with an index of 3. You would repeat this operation some arbitrary number of times generated by calling the random number generator, scaling by a large number and then adding a large number to insure a large minimum number. If you generated a number between 0 and 100 and scaled it by 1000000 and then added 37584 as a minimum you would guarantee that the array would be shuffled between 37584 and 1037584 times. You would shuffle the small numbers in a similar fashion.

Now, given a target number between 1 and 999 and six cards containing numbers that can be used to derive the target, it only remains to give the player 30 seconds to come up with a solution to the problem. But how do we determine if the puzzle even has a solution?

First, we take every combination of the six numbers drawn taken one, two, three, four, five, or six at a time and we combine them using every possible combination of operators. We take each result and store it as either an exact match, a match plus or minus five from the target, a match between six and ten from the target, or else we discard it. Thus, we now know if the puzzle is solvable and we can check the answer that the player gives.

And that is how we analyze and design a program to play the Countdown numbers game. I will use this analysis to actually implement the game. Another time, I’ll analyze and design a program to play the Countdown letters game.


Sweet dreams, don’t forget to tell the ones you love that you love them, and most important of all, be kind.