diff options
| author | Erin van der Veen | 2018-02-06 12:45:05 +0100 | 
|---|---|---|
| committer | Erin van der Veen | 2018-02-06 12:45:05 +0100 | 
| commit | 3c15d4bfa9098a99a7a969f5211b2479d1e0beb5 (patch) | |
| tree | 0e65b503d3d415ee890bee7617755c35ffa1d2c3 /test | |
| parent | Initial commit (diff) | |
Create Test File from Assignment 1, read test file in Main.hs
Diffstat (limited to 'test')
| -rw-r--r-- | test/example1.spl | 109 | 
1 files changed, 109 insertions, 0 deletions
| diff --git a/test/example1.spl b/test/example1.spl new file mode 100644 index 0000000..d5ed535 --- /dev/null +++ b/test/example1.spl @@ -0,0 +1,109 @@ +/* +	Three ways to implement the factorial function in SPL. +	First the recursive version. +*/ +facR(n) :: Int -> Int { +	if (n < 2) { +		return 1; +	} else { +		return n * facR(n - 1); +	} +} + +// The iterative version of the factorial function +faclI(n) :: Int -> Int { +	var r = 1; +	while(n > 1) { +		r = r * n; +		n = n - 1; +	} +	return r; +} + +// A min function to check the results +// It takes no arguments, so the type looks like this: +main() :: -> Void { +	var n = 0; +	var facN = 1; +	var ok = True; +	while(n < 20) { +		facN = facR(n); +		if(facN != facI(n) || facN != facL(n) { +			print(n : facN : facI(n) : facL(n) : []); +			ok = False; +		} +		n = n + 1; +	} +	print(ok); +} + +// A list based factorial function +// Defined here to show that functions can be given in any order (unlike C) +facL(n) :: Int - Int { +	return product(fromTo(1,n)); +} + +// Computes the product of a list of integers +product(list) :: [Int] -> Int { +	if(isEmpty(list)) { +		return 1; +	} else { +		return list.hd * product(list.tl); +	} +} + +// Generates a list of integers from the first to the last argument +fromTo(from, to) :: Int Int -> [Int] { +	if(from <= to) { +		return from : fromTo(from + 1, to); +	} else { +		return []; +	} +} + +// Make a reversed copy of any list +reverse(list) :: [t] -> [t] { +	var accu = []; +	while(!isEmpty(list)) { +		accu = list.hd : accu; +		list = list.tl; +	} +	return accu; +} + +// Absolute value, in a strange layout +abs ( n ) :: Int -> Int {if ( n<0 ) return -n; else return n; } + +// make a copy of a tuple with swapped elements +swapCopy(pair) :: (a, b) -> (b, a) { +	return (pair.snd, pair.fst); +} + +swap(tuple) :: (a, a) -> (a, a) { +	var tmp = tuple.fst; +	tuple.fst = tuple.snd; +	tuple.snd = tmp; +	return tuple; +} + +// list append +aooend(l1, l2) :: [t] [t] -> [t] { +	if(isEmpty(l1)) { +		return l2; +	} else { +		l1.tl = append(l1.tl, l2); +		return l1; +	} +} + +// square the odd numbers in a list and remove the even numbers +squareOddNumbers(list) :: [Int] -> [Int] { +	while(!isEmpty(list) && list.hd % 2 == 0) { +		list = list.tl; +	} +	if(!isEmpty(list)) { +		list.hd = list.hd * list.hd; +		list.tl = squareOddNumbers(list.tl); +	} +	return list; +} | 
