Julia Intro
Juliaet, Wherefore art thou? As Yoda once said… > YAPL - yet another programming language. Learn something new, you must. Why Learn Julia? Julia was designed from the beginning for high performance. Julia programs compile to efficient native code for multiple platforms via LLVM. As such, it’s an interesting programming language to take a look at as it’s a serious contender for certain classes of programming problems; most notibly, scientific and data-centric analysis. Continue readingOCaml OpenGL - Get into Gear!
OCaml and OpenGL - Getting our Functional Programming into Gear! In my blog post for this day, I thought I’d take a look at the OCaml OpenGL library, lablgl. If you’re not already familair with openGL, I strongly suggest that you take a look at one of the tutorials available online. One that I found to be very informative; although written in c++, is opengl-tutorial. Nonetheless, in this post, we’ll look at some simple, and not so simple examples written in OCaml. Continue readingLet's Get Funky with the Camel
How many ways can we get Fun(ky) In any programming paradigm, it’s critical to understand how we write functions - be they traditional imperative , anonymous , recursive, or functional. In this post, I will break down the different types of functions that you can write in OCaml. Let’s start by examining the imperative function. Here’s a simple function that prints out the phrase Hello World! $n$ times, once on each line, and returns the value $n$ as its result. Continue readingOCaml Hello World and more
Well Hello There! As tradition has it, every new programming language experience must begin with the basic Hello World. Let’s walk the the basics of how to set up our development environment specifically for OCaml and demonstrate how to compile our basic program. Warming up our Environment Of course we could just use our vanilla editor to enter our OCaml programs, but a more efficient work environment leverages an extensible editor that is aware of our programming language. Continue readingRecursion Revisited
Recursion, from more than one point-of-view.
A common programming idiom in computer science is solving a problem by self-reference, also known as recursion. In this post, we look at two different implementations of the same problem.
Solve a recursive problem in two different programming language paradigms
Let’s look at the solution to a simple problem, compute $f(x)=e^{x}$.
We will illustrate two separate solutions - one in a procedural language (python), and the other in a functional language (elixir).
Let’s start off with the functional language. Were does recursion come into play?
We define the function $f(x)=e^x$ as the infinite sum, $\text{ }f(x) = \sum_{n=0}^\infty{\frac{x^n}{n!}}$
In our solution below, we define two separate recursive functions, exp/2
and fac/1
. What’s interesting to note here is how each of these functions has two separate definitions. This is an aspect of programming in elixir that elegantly uses pattern-matching to return different results depending upon the input. Our two functions nicely dovetail into the base-case and recursive case of a recursive algorithm.
For example, looking at exp/2
, the first function definition returns 1 for any value of x (as indicated by the _
preceding the variable) and returns 1. This is the mathematical equivalent of $x^0=1\text{ for any }x$.
The second definition of exp/2
is the recursive case. for any value of $n\gt0$. Moreover, we define exp(x, n)
as $\frac{e^x}{n!}$ + exp(x, n-1)
.
Similarly for the definition of fac/1
we see two definitions; one for $n=0$ and another for all values of $n\gt0$.