Subscribe to Personal Log via RSS and find other blogs to read in my blogroll.

Just tell it what you want

I’m reading Functional Programming, Simplified by Alvin Alexander, which is intended to make the process of learning functional programming (FP) in Scala as simple as possible.

It is a bit too soon to recommend the book, and it is a 700+ pages commitment –I’m glad it is simplified–, but I’m happy with what I’ve been reading so far.

In the introductory chapters, where Alexander starts to define what is FP, he includes a quote attributed to experienced FP developers:

In FP we don’t tell the computer how to do things, we just tell it what we want.

The idea behind the quote is that, in imperative programming, the programmer tells the compiler step by step what to do, while in FP you are telling what is what you want to be done, without caring about the actual implementation.

Instead of reproducing the same example from the book, let’s take a look at this short piece of C code:

char *leters = "aababcbcdefba";
int count = 0;

for (int i = 0; i < 13; i++)
    if (leters[i] == 'a')
        count++;

In this example we are counting how many times the character ‘a’ appears on a string. Very straightforward, isn’t it?

Let’s see how we would do this in Scala using FP:

"aababcbcdefba".count(_ == 'a')

Do I really care how count is implemented? No, I don’t; all I want is to know how many times the character ‘a’ appears on that string, and I can trust that function to be correctly implemented.

Although the point Alexander was making was not explicitly about the quote itself, it really resonated with me because I’ve been thinking about something similar in the context of a compiler targeting limited CPUs like the Z80.

One of the common struggles of making games for 8-bit microcomputers using C and the SDCC compiler is that the compiler is not always very efficient generating Z80 code. And thinking about imperative programming, it makes sense that it is hard.

I suspect the real reason for SDCC not being at the same level as other modern compilers is more related to resources and limitations of the target architecture; for example the Z80 has less registers than a modern CPU, and writing an efficient register allocator is a big part of the problem.

Anyway, I was wondering if a compiler that implemented some limited functional programming language would have an easier job if instead of telling it how to do things, we just tell it what we want.

Hello, blog

This is the first post on this blog, exciting!

Really? Are blogs still exciting in 2021? Well, I think they are, even if not as popular as they used to be, specially compared with social media. I’m convinced there are blogs worth reading out there.

I also think there’s value in writing a blog, in my case to document my projects, and as a way to somehow untangle my thoughts when I have something to say.

Which is what I was doing, more or less, on Twitter. Until recently, that I decided to review how I use that social network. With current COVID situation (and working from home), I found that the always on of Twitter was starting to affect my ability to switch off, and it was an easy gateway to procrastination and losing my scarce free time to get things done.

I haven’t decided yet what I’m going to do with my Twitter account, because I have 2400+ followers, and that is very useful when I want to promote one of my games. It’ll be just that I’m not going to be there.

As you may know, I already write in a blog in Spanish that I’ve been writing since 2003 (that’s 18 years already!), but I wanted to do some things differently:

  • I want to have the blog as part of this site.
  • because this site is generated with Hugo, I won’t be using a full featured CMS.
  • write in English, as I was doing on Twitter.

So, what is this going to be about? I suspect it’s going to be similar to what I used to write on Twitter: about my gamedev projects, with some WIP content, about Open Source and technology, perhaps some commentary on news, and likely to have more lengthy writings as well, because this is a blog after all!

The blog is currently a bit work in progress, and I may add more things as I think I need them (like making the posts’ tags visible). But for now, this is a good first post.

Like and subscribe!