summaryrefslogtreecommitdiff
path: root/minijazz/test/nadder.mj
diff options
context:
space:
mode:
Diffstat (limited to 'minijazz/test/nadder.mj')
-rw-r--r--minijazz/test/nadder.mj19
1 files changed, 19 insertions, 0 deletions
diff --git a/minijazz/test/nadder.mj b/minijazz/test/nadder.mj
new file mode 100644
index 0000000..a5a6a17
--- /dev/null
+++ b/minijazz/test/nadder.mj
@@ -0,0 +1,19 @@
+fulladder(a,b,c) = (s, r) where
+ s = (a ^ b) ^ c;
+ r = (a & b) + ((a ^ b) & c);
+end where
+
+adder<n>(a:[n], b:[n], c_in) = (o:[n], c_out) where
+ if n = 0 then
+ o = [];
+ c_out = 0
+ else
+ (s_n1, c_n1) = adder<n-1>(a[1..], b[1..], c_in);
+ (s_n, c_out) = fulladder(a[0], b[0], c_n1);
+ o = s_n . s_n1
+ end if
+end where
+
+main(a:[2], b:[2]) = (o:[2], c) where
+ (o, c) = adder<2>(a,b,0)
+end where \ No newline at end of file