Wednesday, January 13, 2010

I've got what I think is a neat idea...

I'm going to sit on it until I get my first paycheck of the year, and work on stuff behind the scenes, like.

I'm not sure how that was supposed to be punctuated.  But things will be happening, oh yes.

Sunday, January 10, 2010

Some hyatt revelations

Functions should be handled by the output domain.  This is because function execution should, in essence, propagate inward: one function has other functions as arguments, and each of those arguments is typed, so that domain is queried if the argument is the result of a function evaluation.

EDIT: actually, that might be the opposite of how I wanted to do it.  I'll need some hypothetical situations to buffer up my position (the issue is overloading).  Either way, good on me for remembering about the existence of vector domains, which make this whole setup much more sensible.

EDITx2: Functions are identified by signature, which means that they should be stored by parameter domain and name.  To determine functions higher up, first find the output domain, and feed that to the function in question.

Saturday, January 9, 2010

To-Do for Hyatt, at the moment

Transition code outside of domain.py to use the new "terquid" class. EDIT: maybe done.  To the extent that it's not done, related tasks not detailed here have a higher priority.
Change the serialization and deserialization methods to support empty terquids.  EDIT: done.
Give terquids exceptional support, or vice-versa.  EDIT: exceptionals are now a subclass of terquid (but see below)
Think of a better name than "terquid".  EDIT: terquid is now "mem"

Friday, January 8, 2010

Yay! Progress!

Work continues apace on Hyatt, the RDBMS for elitists.  The constraint model has been cleaned up.  It now features fewer irrelevant functions and a robust logical model that will give most of the people who attempt to use it fits.  Next, I need to do some work to get vector domains into a sensible place, and to overhaul the function specification system for domains.

Current idea for that last one: function specs consist of a tuple of the function itself, and the domain of any arguments beyond the first one.  The first one must be of the defined domain.  To allow binary functions such as addition, there'll be a dummy object that gets replaced with the domain in question during class creation.  Ugh... something is fishy with all that...

Idea: domains are created solely as specifications of permissible data, using several validation functions, with default constraint objects.  (In other words, they have a default coercer, which can be overridden in specific instances.)  Functions register themselves with domains after those domains exist.