-- The sum of a sequence of numerics.
sum: seqofreal +> real
sum(s) == fold[real](Numeric`add,0,s);
-- The product of a sequence of numerics.
prod: seqofreal +> real
prod(s) == fold[real](Numeric`mult,1,s);
-- The minimum of a sequence of numerics.
min: seq1ofreal +> real
min(s) == fold1[real](Numeric`min,s) postRESULTinsetelems s andforall e insetelems s & RESULT <= e;
-- The maximum of a sequence of numerics.
max: seq1ofreal +> real
max(s) == fold1[real](Numeric`max,s) postRESULTinsetelems s andforall e insetelems s & RESULT >= e;
-- Does an element appear in a sequence?
inSeq[@a]: @a * seqof @a +> bool
inSeq(e,s) == e insetelems s;
-- The position an item appears in a sequence?
indexOf[@a]: @a * seq1of @a +> nat1
indexOf(e,s) == cases s:
[-] -> 1,
[f]^ss -> if e=f then 1 else 1 + indexOf[@a](e,ss) end pre inSeq[@a](e,s) measure size0;
-- The position a subsequence appears in a sequence.
indexOfSeq[@a]: seq1of @a * seq1of @a +> nat1
indexOfSeq(r,s) == if preSeq[@a](r,s) then 1 else 1 + indexOfSeq[@a](r, tl s) pre subSeq[@a](r,s) measure size3;
-- The position a subsequence appears in a sequence?
indexOfSeqOpt[@a]: seq1of @a * seq1of @a +> [nat1]
indexOfSeqOpt(r,s) == if subSeq[@a](r,s) then indexOfSeq[@a](r, s) elsenil;
-- The number of times an element appears in a sequence.
numOccurs[@a]: @a * seqof @a +> nat
numOccurs(e,sq) == len [ 0 | i insetinds sq & sq(i) = e ];
-- Is one sequence a permutation of another?
permutation[@a]: seqof @a * seqof @a +> bool
permutation(sq1,sq2) == len sq1 = len sq2 and forall i insetinds sq1 & numOccurs[@a](sq1(i),sq1) = numOccurs[@a](sq1(i),sq2);
-- Is one sequence a prefix of another?
preSeq[@a]: seqof @a * seqof @a +> bool
preSeq(pres,full) == pres = full(1,...,len pres);
-- Is one sequence a suffix of another?
postSeq[@a]: seqof @a * seqof @a +> bool
postSeq(posts,full) == preSeq[@a](reverse posts, reverse full);
-- Is one sequence a subsequence of another sequence?
subSeq[@a]: seqof @a * seqof @a +> bool
subSeq(sub,full) == exists i,j insetinds full & sub = full(i,...,j);
-- Pad a sequence on the left with a given item up to a specified length.
padLeft[@a]: seqof @a * @a * nat +> seqof @a
padLeft(sq,x,n) == [ x | i inset {1 ,..., n - len sq} ] ^ sq;
-- Pad a sequence on the right with a given item up to a specified length.
padRight[@a]: seqof @a * @a * nat +> seqof @a
padRight(sq,x,n) == sq ^ [ x | i inset {1 ,..., n - len sq} ];
-- Pad a sequence on the right with a given item up to a specified length.
padCentre[@a]: seqof @a * @a * nat +> seqof @a
padCentre(sq,x,n) == let space = if n <= len sq then 0 else n - len sq in padRight[@a](padLeft[@a](sq,x,len sq + (space div 2)),x,n);
-- Apply a function to all elements of a sequence.
xform[@a,@b]: (@a+>@b) * seqof @a +> seqof @b
xform(f,s) == [ f(s(i)) | i insetinds s ] postlenRESULT = len s;
-- Fold (iterate, accumulate, reduce) a binary function over a sequence. -- The function is assumed to be associative and have an identity element.
fold[@a]: (@a * @a +> @a) * @a * seqof @a +> @a
fold(f, e, s) == cases s:
[] -> e,
[x] -> x,
s1^s2 -> f(fold[@a](f,e,s1), fold[@a](f,e,s2)) end --pre (exists x:@a & forall y:@a & f(x,y) = y and f(y,x) = y) --and forall x,y,z:@a & f(x,f(y,z)) = f(f(x,y),z) measure size2;
-- Fold (iterate, accumulate, reduce) a binary function over a non-empty sequence. -- The function is assumed to be associative.
fold1[@a]: (@a * @a +> @a) * seq1of @a +> @a
fold1(f, s) == cases s:
[e] -> e,
s1^s2 -> f(fold1[@a](f,s1), fold1[@a](f,s2)) end --pre forall x,y,z:@a & f(x,f(y,z)) = f(f(x,y),z) measure size1;
-- Pair the corresponding elements of two lists of equal length.
zip[@a,@b]: seqof @a * seqof @b +> seqof (@a * @b)
zip(s,t) == [ mk_(s(i),t(i)) | i insetinds s ] prelen s = len t postlenRESULT = len s;
-- Split a list of pairs into a list of firsts and a list of seconds.
unzip[@a,@b]: seqof (@a * @b) +> seqof @a * seqof @b
unzip(s) == mk_([ s(i).#1 | i insetinds s], [ s(i).#2 | i insetinds s]) postlet mk_(t,u) = RESULTinlen t = len s andlen u = len s;
-- Are the elements of a list distinct (no duplicates).
isDistinct[@a]: seqof @a +> bool
isDistinct(s) == len s = cardelems s;
-- The following functions wrap primitives for convenience, to allow them for example to -- serve as function arguments.
-- Concatenation of two sequences.
app[@a]: seqof @a * seqof @a +> seqof @a
app(m,n) == m^n;
-- Set of sequence elements.
setOf[@a]: seqof @a +> setof @a
setOf(s) == elems(s);
Die Informationen auf dieser Webseite wurden
nach bestem Wissen sorgfältig zusammengestellt. Es wird jedoch weder Vollständigkeit, noch Richtigkeit,
noch Qualität der bereit gestellten Informationen zugesichert.
Bemerkung:
Die farbliche Syntaxdarstellung ist noch experimentell.