]> Repositorios git - scryer-prolog.git/commitdiff
Implemented lsb/2 and msb/2
authornotoria <[email protected]>
Fri, 24 Apr 2020 20:47:24 +0000 (22:47 +0200)
committernotoria <[email protected]>
Fri, 24 Apr 2020 21:52:32 +0000 (23:52 +0200)
src/prolog/lib/arithmetic.pl [new file with mode: 0644]

diff --git a/src/prolog/lib/arithmetic.pl b/src/prolog/lib/arithmetic.pl
new file mode 100644 (file)
index 0000000..ab691a0
--- /dev/null
@@ -0,0 +1,25 @@
+:- module(arithmetic, [msb/2, lsb/2]).
+
+lsb(X, N) :-
+    builtins:must_be_number(X, lsb/2),
+    (   \+ integer(X) -> throw(error(type_error(integer, X), lsb/2))
+    ;   X < 1 -> throw(error(domain_error(not_less_than_one, X), lsb/2))
+    ;   builtins:can_be_number(N, lsb/2),
+        X1 is X /\ (-X),
+        msb_(X1, -1, N)
+    ).
+
+msb(X, N) :-
+    builtins:must_be_number(X, msb/2),
+    (   \+ integer(X) -> throw(error(type_error(integer, X), msb/2))
+    ;   X < 1 -> throw(error(domain_error(not_less_than_one, X), msb/2))
+    ;   builtins:can_be_number(N, msb/2),
+        X1 is X >> 1,
+        msb_(X1, 0, N)
+    ).
+
+msb_(0, N, N) :- !.
+msb_(X, M, N) :-
+    X1 is X >> 1,
+    M1 is M + 1,
+    msb_(X1, M1, N).