[ Arithmetic | Reference Manual | Alphabetic Index ]

clrbit(+Number, +Index, -Result)

Result is Number with the Index'th bit cleared.
Non-negative integer.
Output: integer.


Clear the Index'th bit in Number giving Result. The least significant bit has index zero. Two's complement representation is assumed. This predicate is used by the ECLiPSe compiler to expand evaluable arithmetic expressions. So the call to clrbit(Number, Index, Result) is equivalent to
    Result is clrbit(Number, Index)
which should be preferred.

In coroutining mode, if Number or Index are uninstantiated, the call is delayed until these variables are instantiated.

Modes and Determinism


(4) instantiation fault
Number or Index is not instantiated (non-coroutining mode only).
(5) type error
Number or Index is a number but not an integer.
(24) number expected
Number or Index is not of a numeric type.


    Result is clrbit(15, 3).		% gives Result = 7
    Result is clrbit(40, 3).		% gives Result = 32
    Result is clrbit(setbit(0,5),5).    % gives Result = 0

See Also

is / 2, setbit / 3, getbit / 3