\documentclass{article}
\usepackage{axiom}
\begin{document}
\title{\$SPAD/src/input streams.input}
\author{The Axiom Team}
\maketitle
\begin{abstract}
\end{abstract}
\eject
\tableofcontents
\eject
\section{License}
<<license>>=
--Copyright The Numerical Algorithms Group Limited 1991.
@
<<*>>=
<<license>>

)clear all
)set streams calculate 5
)set streams showall on
--at least 5 stream elements will be evaluated
--the stream of integers starting at 1
a := [i for i in 1..]
b := [i+1 for i in a]
--select the 20th element
b.20
--the first 20 elements of b (and a) are evaluated
b
a
--the first 10 elements of a
first(a,10)
--all except the first 10 elements of a
rest(a,10)
--the stream of odd integers
[i for i in a | odd? i]
--combining two streams
c := [[i,j] for i in a for j in b]
-- selecting the first from each pair
[first i for i in c]
)set streams calculate 10
--concat(a,b) concatenates streams a and b, better if a is finite
concat([i for i in a while i<7],a)
concat(a,a)
upto:NNI->STREAM INT
upto n == first(a,n)
d := [upto n for n in a]
--concat flattens a stream of streams into a one level stream
concat d
--the sum of a finite stream
reduce(0,_+$INT,first(a,10))
--a stream of cumulative sums
scan(0,_+$INT,a)
scan(0,_+$INT,[2*i-1 for i in a])
ff:(LIST INT)->(LIST INT)
ff(x)==[x.1+x.2,x.1]
--generate(f,x) operates on an A->A function f and an initial A, x
--to produce the stream x,f x,f(f x),...
fibs := generate(ff,[1,1])
--first([first i for i in fibs], 100)
mt:SQMATRIX(2,INT) := matrix [[1,2],[3,4]]
mplm:SQMATRIX(2,INT)->SQMATRIX(2,INT)
mplm x == x*mt
generate(mplm,mt)
@
\eject
\begin{thebibliography}{99}
\bibitem{1} nothing
\end{thebibliography}
\end{document}