UNPKG

algebrite

Version:

Computer Algebra System in Coffeescript

57 lines (41 loc) 749 B
# 'sum' function #define A p3 #define B p4 #define I p5 #define X p6 # leaves the sum at the top of the stack Eval_sum = -> i = 0 j = 0 k = 0 # 1st arg (quoted) p6 = cadr(p1) if (!issymbol(p6)) stop("sum: 1st arg?") # 2nd arg push(caddr(p1)) Eval() j = pop_integer() if (isNaN(j)) stop("sum: 2nd arg?") # 3rd arg push(cadddr(p1)) Eval() k = pop_integer() if (isNaN(k)) stop("sum: 3rd arg?") # 4th arg p1 = caddddr(p1) # remember contents of the index # variable so we can put it back after the loop p4 = get_binding(p6) push_integer(0) for i in [j..k] push_integer(i) p5 = pop() set_binding(p6, p5) push(p1) Eval() add() # put back the index variable to original content set_binding(p6, p4)