I've been working hard lately to hit all of my release goals so I could get a new, improved version of Scotch out the door.
You can read about the changes (or the basics) in the new documentation. Aside from a lot of new functionality, one improvement that I'm really happy about is just-in-time compilation. This results in a dramatic speedup by greatly reducing the number of times each module is parsed. Previously, parsing accounted for all of the major cost centers affecting running time. A big culprit was std.lib, which is loaded at startup and then reloaded into every other imported module as it was interpreted. JIT compilation has resulted in about a 10x speedup for the cases I tested, making Scotch once again faster (again, for specific benchmarks being tested) than object oriented languages in its class such as Python and Ruby.
A Scotch website is in the works, but for now you can head to http://scotchlang.org which is a redirect to the front Wiki page of the Github project. Downloads are available here. And, check out the build instructions here.
Friday, January 28, 2011
Thursday, January 20, 2011
Support Scotch
Throw in a couple bucks and keep Scotch going!
You can now donate to support continued development of Scotch via Pledgie/PayPal using this button:
Scotch has been developed so far using a lot of my spare time, which I now have very little of. Scotch has already implemented some cool ideas and is definitely the first language of its kind, and there are still a lot of cool plans for the future. Your donation will be used to fund development and other direct costs (hosting, for example) associated with Scotch, and every dollar will be accounted for.
Our first goal is to acquire a used Mac Mini (around $350) so that we can build Mac packages and support Mac users better.
You can also support Scotch by helping with development, or by spreading the word.
You can now donate to support continued development of Scotch via Pledgie/PayPal using this button:
Scotch has been developed so far using a lot of my spare time, which I now have very little of. Scotch has already implemented some cool ideas and is definitely the first language of its kind, and there are still a lot of cool plans for the future. Your donation will be used to fund development and other direct costs (hosting, for example) associated with Scotch, and every dollar will be accounted for.
Our first goal is to acquire a used Mac Mini (around $350) so that we can build Mac packages and support Mac users better.
You can also support Scotch by helping with development, or by spreading the word.
Friday, January 14, 2011
Scotch : Haskell :: Python : C
A new programming language is useless if it doesn't solve a problem. With that in mind, I want to explore the main problem that Scotch solves.
Let's start with an analogy that expresses the basic motivation behind Scotch: Scotch aims to do for functional programming what Python has done for imperative. Or, in other words, Scotch : Haskell :: Python : C.
In terms of functionality, little of Scotch is new, although I do think the type system sets it apart from popular languages. Many significant functional programming languages already exist: Haskell, the Lisp family, the ML family, F#...so why do we need a new one?
Fortunately, Scotch has an important use case that none of these languages covers: it's an easy-to-use scripting language. Scotch is interpreted, its syntax is intuitive, its type system won't fight you, variable definitions can be redefined, and types never need to be declared: all features it shares with Python and Ruby, not other functional languages. A good developer equally familiar with Scotch and Haskell or Lisp or some other functional language will be able to throw a simple project together faster in Scotch. I'd also wager that, all things equal, this developer would be able to develop faster in Scotch than in Python, just as Python enables faster development than C.
Why?
I like to compare Scotch to Python; both are basically a bundle of things that have been done before, but both emphasize readability and developer productivity as two major selling points. Python achieves better readability in part by using simple, intuitive syntax. I would say that Scotch goes even farther in this direction because its syntax is almost identical to the most common, understandable notation in existence: math.
Take this example of function definition. In Python:
def area(length, width):
return length * width
In Haskell:
area :: (Int a) => a -> a -> a
area length width = length * width
Scotch:
area(length, width) = length * width
And in math:
A(l, w) = lw
To avoid identifier ambiguity, the Scotch version is not quite the same as math, but I'd say it's close enough. Comparing the first three, the third is more concise; to anyone with a basic math background, it is also more intuitive.
Computer programs express mathematics. Historically, programming languages have contorted mathematical notation to do things we wanted to do. With Scotch, the program looks like the math that it expresses. I believe that scientists, mathematicians, or anyone who uses math in their daily lives (that's everyone) will be able to read and understand a Scotch program - instead of learning a new "language," they simply have to learn how to apply a language with which they're already familiar.
I didn't develop Scotch to be popular; I invented it to scratch my own itch, creating a kind of hybrid of two of my favorite languages, Haskell and Python. At the moment, I've written more Scotch than anyone else on Earth (and I imagine it will stay that way for some time). The verdict: I've found developing the Scotch standard library to be a refreshingly painless experience compared to other languages I've worked in.
Let's start with an analogy that expresses the basic motivation behind Scotch: Scotch aims to do for functional programming what Python has done for imperative. Or, in other words, Scotch : Haskell :: Python : C.
In terms of functionality, little of Scotch is new, although I do think the type system sets it apart from popular languages. Many significant functional programming languages already exist: Haskell, the Lisp family, the ML family, F#...so why do we need a new one?
Fortunately, Scotch has an important use case that none of these languages covers: it's an easy-to-use scripting language. Scotch is interpreted, its syntax is intuitive, its type system won't fight you, variable definitions can be redefined, and types never need to be declared: all features it shares with Python and Ruby, not other functional languages. A good developer equally familiar with Scotch and Haskell or Lisp or some other functional language will be able to throw a simple project together faster in Scotch. I'd also wager that, all things equal, this developer would be able to develop faster in Scotch than in Python, just as Python enables faster development than C.
Why?
I like to compare Scotch to Python; both are basically a bundle of things that have been done before, but both emphasize readability and developer productivity as two major selling points. Python achieves better readability in part by using simple, intuitive syntax. I would say that Scotch goes even farther in this direction because its syntax is almost identical to the most common, understandable notation in existence: math.
Take this example of function definition. In Python:
def area(length, width):
return length * width
In Haskell:
area :: (Int a) => a -> a -> a
area length width = length * width
Scotch:
area(length, width) = length * width
And in math:
A(l, w) = lw
To avoid identifier ambiguity, the Scotch version is not quite the same as math, but I'd say it's close enough. Comparing the first three, the third is more concise; to anyone with a basic math background, it is also more intuitive.
Computer programs express mathematics. Historically, programming languages have contorted mathematical notation to do things we wanted to do. With Scotch, the program looks like the math that it expresses. I believe that scientists, mathematicians, or anyone who uses math in their daily lives (that's everyone) will be able to read and understand a Scotch program - instead of learning a new "language," they simply have to learn how to apply a language with which they're already familiar.
I didn't develop Scotch to be popular; I invented it to scratch my own itch, creating a kind of hybrid of two of my favorite languages, Haskell and Python. At the moment, I've written more Scotch than anyone else on Earth (and I imagine it will stay that way for some time). The verdict: I've found developing the Scotch standard library to be a refreshingly painless experience compared to other languages I've worked in.
Sunday, January 9, 2011
Scotch 0.2.0 is out
School starts tomorrow, so my spare time is going to disappear for a bit. With that in mind, I'm packaging Scotch as version 0.2.0 as a release at GitHub (head to the "downloads" page.)
For help getting started, check out these code examples.
Version 0.1 was a prototype that I released just to get something up. Some significant improvements in 0.2.0 include:
For help getting started, check out these code examples.
Version 0.1 was a prototype that I released just to get something up. Some significant improvements in 0.2.0 include:
- Significantly more efficient - features like tail recursion and a hash table for variable/function bindings enable version 0.2.0 to run much faster
- File input/output
- Support for threads
- Implemented hash tables
- Algebraic data types
- Anonymous functions
- Expanded std.lib with more useful functions
- Native implementation of Scotch interpreter, in Scotch
- Scotch-to-C compiler
- Just-in-time compilation to an intermediate format - this will likely result in about a 50% speedup
- Systems programming
- Infinite lists
Monday, January 3, 2011
What's New with Scotch: 1/3/11
Here's a summary of some new features that have been recently added in Scotch:
Threads
Scotch now supports lightweight threads (lwt), which currently borrows from the Haskell lwt model. They can be used like this:
>> thread (do print 1; print 2; print 3;)
1
2
3
>> a = do print 1; print 2;
>> b = thread a;
>> execute([b] * 2)
1
2
1
2
Currently, state is not shared between threads; some sort of simple shared variables is needed, and it's on my to do list.
Algebraic Data Types
The ADT model is considerably different from other functional languages because of Scotch's type system. For object-oriented programmers, ADT are kind of like lightweight classes that you don't need to define before you use (but without encapsulation - in functional programming, behavior is handled by functions, not methods.)
For example:
>> Apple
Apple
>> Apple 1
Apple 1
>> Apple (Banana(1,2,3))
...
So, a custom type is an Atom (WhichLooksLikeThis) followed by any number of values (if there are more than one, parentheses are needed to eliminate ambiguity.) These custom datatypes can be used in function pattern matches like so:
>> a = Apple 1
>> f(Apple a) = a
>> f(a)
1
This pattern matches Apple followed by a value, and binds 'a' to that value.
Anonymous Functions
Wherever a function would be passed as an argument, like in this example...
>> apply(f, x) = f(x)
>> apply(add(10), 5)
15
...an anonymous function can also be used, which looks like this:
>> apply(a -> a + 10, 5)
15
This allows you to define functions without binding them to a variable. (Incidentally, these functions are a type of value, so they can be bound to a variable if you feel like it: f = a, b -> a + b)
Threads
Scotch now supports lightweight threads (lwt), which currently borrows from the Haskell lwt model. They can be used like this:
>> thread (do print 1; print 2; print 3;)
1
2
3
>> a = do print 1; print 2;
>> b = thread a;
>> execute([b] * 2)
1
2
1
2
Currently, state is not shared between threads; some sort of simple shared variables is needed, and it's on my to do list.
Algebraic Data Types
The ADT model is considerably different from other functional languages because of Scotch's type system. For object-oriented programmers, ADT are kind of like lightweight classes that you don't need to define before you use (but without encapsulation - in functional programming, behavior is handled by functions, not methods.)
For example:
>> Apple
Apple
>> Apple 1
Apple 1
>> Apple (Banana(1,2,3))
...
So, a custom type is an Atom (WhichLooksLikeThis) followed by any number of values (if there are more than one, parentheses are needed to eliminate ambiguity.) These custom datatypes can be used in function pattern matches like so:
>> a = Apple 1
>> f(Apple a) = a
>> f(a)
1
This pattern matches Apple followed by a value, and binds 'a' to that value.
Anonymous Functions
Wherever a function would be passed as an argument, like in this example...
>> apply(f, x) = f(x)
>> apply(add(10), 5)
15
...an anonymous function can also be used, which looks like this:
>> apply(a -> a + 10, 5)
15
This allows you to define functions without binding them to a variable. (Incidentally, these functions are a type of value, so they can be bound to a variable if you feel like it: f = a, b -> a + b)
Subscribe to:
Posts (Atom)