The reason that 'plus (f,g) == x+->f(x)+g(x)' fails in interpreter may
have nothing to do with type system, but because of interpreter can
not handle closure:
For example, the 'adder' function:
adder x == y +-> y + x
It totally works in Spad form, but in interpreter:
(2) -> q := adder 3
Compiling function adder with type PositiveInteger ->
AnonymousFunction
(2) y +-> y + #1
Type: AnonymousFunction
(3) -> q 4
(3) #1 + 4
Type: Polynomial(Integer)
The '#1' should be the captured value of 'x', thus 3.
So, interpreter can not handle captured variable, aka closure,
this is a bug, am I right?
--
You received this message because you are subscribed to the Google Groups
"FriCAS - computer algebra system" group.
To unsubscribe from this group and stop receiving emails from it, send an email
to [email protected].
To post to this group, send email to [email protected].
Visit this group at http://groups.google.com/group/fricas-devel.
For more options, visit https://groups.google.com/d/optout.