I wasn't thinking totally clearly at 3am, so around 4:30 I thought of
some things that I didn't ask. =)
(You may notice that I'm coming from an event-driven paradigm...I'm
trying to map my understanding of how mine works onto Cells and "make
sure" Cells is a superset of what I'm using).
5) Multi-method (?) calculations: I've seen simple examples in the
Cells docs that show a slot being dependent on another slot. It looks
like you install this computation in the "destination" slot, i.e. the
…
[View More]one that's dependent. What if you've got a situation where you have
five slots, A B C D and E, that are parts of say three different
objects, O1 O2 and O3. There's one computation that needs A B C D and
E, and ends up modifying slots F G H and I in objects O4 and O5. Can
it be done, making a single computation that depends on many slots in
different instances that then updates slots in many instances? Or do
you need to decompose this computation into (complicated!) pieces to
be installed in each of the destination slots (F G H and I)? Can a
change in one or more of A B C D and E cause a computation that
updates C D F and G? (I.e. C and D are both inputs *and* outputs of
the calculation. Note that self-cycling must be avoided!).
6) Multiple "owners" of responsibility, or aspect separation: (this
is related to #5 above) What if you have a normal calculation that
happens 99% of the time that changes slot A into slot B (B is
dependent on A). You write the formula into the slot code for B, and
you're happy. But then, because of some strange requirement or other
complicated design issue, you realize that B also depends, every once
in a while (say 1%), on C D and E. But you don't want to stick this
new computation and dependency code with the original code, because it
will not only clutter reading, but also the complicated process may
change in the future. So you want to keep the concerns separate, i.e.
the two different "times" when B can change. Is there a way in Cells
to make two different pieces of code that show two different ways that
slot B is dependent on other slots?
7) "Lazy" updates: Probably a bad term for this, not to be confused
with strict and non-strict argument evaluation. Nonetheless, let's
say you have a slot A that depends on B C D and E. B and C are
absolutely critical to A's computation, and every single time they
change, you need to enforce that A is recomputed. My guess is that
Cells works like this already, automatically. However, let's say D
and E change their values inordinately fast, like maybe they're mouse
X and Y coordinates on the screen. Let's also say that the
computation for A is non-trivial, and you want to run it only when
absolutely necessary. Further, although A needs the current mouse X
and Y coordinates, it doesn't make sense to recompute A every time
they change. Is there a way to tell Cells that A should be recomputed
*every* time that B and C change, but also needs access to cells D and
E while not "firing" every time they change?
Sorry if this sounds stupidly simple, but remember, I'm projecting my
domain onto yours, so I'm pretty new at this.
8) Phase-based calculation, or data "wave" propagation: If a slot A
depends on slots B C and D...when will A get recomputed? Every time
that B C or D change, right? What if two other computations change
both C and D as a result of a single slot change in E...does Cells
defer the running of A until *both* C and D have been recalculated
(i.e. enforced breadth-first dependency graph traversal), or will the
calculation of A happen twice, once when C changes and once when D
changes (i.e. random, depth-first, or other traversal)?
9) Introspection: How easy is it to determine the full dependency
graph of interrelated computation given a system coded using Cells?
I.e., other than of course looking at the code, can I use a
programmatic method to determine the topology of the dependencies in
order to, for instance, produce a visual graph of the system? Is this
introspection system static, or dynamic (i.e. allow callback hooks or
the like to update changes in the system as they happen)?
Thanks again for any comments.
Mike
--
Mike J. Bell on gmail
[View Less]
Peter Denno wrote:
>On Saturday 05 March 2005 10:24, Kenny Tilton wrote:
>
>
>>Yes. There is an :unchanged-if option (default EQL (supplied by Cells
>>internals)) on slot definitions in DEFMODEL:
>>
>>Example from Cello:
>>(defmodel image (ogl-node model)
>> ((clipped :cell nil :initarg :clipped :initform nil :reader clipped)
>> (inset :initarg :inset
>> :unchanged-if 'v2=
>>
>>
>
>I would have thought …
[View More]that :unchanged-if would take a function of one value.
>Are you saying here that it still uses EQL, but instead of checking against
>old-value #'(lambda (x) (eql old-value new-value)) it is doing #'(lambda (x)
>(eql new-value 'v2=)) ?
>
>
>
A function of one value? No, the question is whether the prior value
calculated by a rule is the same as the latest value calculated because
some dependency changed. The prototype would be:
(defun custom-change-test (latest-value prior-value)....
Here is the relevant code, massively edited/simplified here to make the
flow apparent:
(defmethod md-slot-value-assume (c raw-value)
(let ((prior-state (c-value-state c))
(prior-value (c-value c))
(absorbed-value (c-absorb-value c raw-value)))
(unless (and (eql prior-state :valid)
(c-no-news c absorbed-value prior-value))
(setf (c-changed c) t)
(c-propagate c prior-value (not (eql :unbound prior-state)))))
absorbed-value)))
;----------------- change detection ---------------------------------
(defun c-no-news (c new-value old-value)
(bif (test (c-unchanged-test (c-model c) (c-slot-name c)))
(funcall test new-value old-value)
(eql new-value old-value)))
kt
--
Cells? Cello? Cells-Gtk?: http://www.common-lisp.net/project/cells/
Why Lisp? http://lisp.tech.coop/RtL%20Highlight%20Film
"Doctor, I wrestled with reality for forty years, and I am happy to state that I finally won out over it." -- Elwood P. Dowd
[View Less]