login  home  contents  what's new  discussion  bug reports     help  links  subscribe  changes  refresh  edit

Submitted by : (unknown) at: 2007-11-17T22:08:45-08:00 (17 years ago)
Name :
Axiom Version :
Category : Severity : Status :
Optional subject :  
Optional comment :

The coersion to InputForm produces a lispy representation for most types. E.g.

fricas
(1) -> )set output tex off
 
fricas
)set output algebra on

fricas
p:POLY INT:=x^2+1
2 (1) x + 1
Type: Polynomial(Integer)
fricas
pSex:=p::InputForm
(2) (+ (^ x 2) 1)
Type: InputForm
fricas
p1:=interpret(pSex)
2 (3) x + 1
Type: Polynomial(Integer)

But this fails for functions

fricas
f:INT->INT
Type: Void
fricas
f(x) == x^2+1
Type: Void
fricas
-- force compile
f(2)
fricas
Compiling function f with type Integer -> Integer 
(6) 5
Type: PositiveInteger?
fricas
fSex:=f::InputForm
(7) (coerceOrCroak (CONS '(Mapping (Integer) (Integer)) (wrap (SPADMAP (#1 + (^ #1 2) 1)))) '(InputForm) 'noMapName)
Type: InputForm

So far so good, but

fricas
f1:=interpret(fSex)
Cannot convert the value from type (Integer -> Integer) to InputForm .

Category: Aldor Library Compiler => Axiom Library

This is a problem with AXIOMs? not making their minds about whether a map should be treated as a value in its own, or whether it is an expression that needs further evaluation to yield a value. The proper fix is to have all user defined maps treated as values in their owns -- e.g. their representation in the interpreter environment should be wrapped. However, that requires a more extensive patch to implement. But, that is the right thing to do.

Severity: normal => minor




  Subject: (replying)   Be Bold !!
  ( 15 subscribers )  
Please rate this page: