BIT. - Work with Bits

<< Click to Display Table of Contents >>

Navigation:  3. Script Language > BIT. - Work with Bits >

BIT. - Work with Bits

BIT.AND - Use logical AND with Bits

Previous Top Next


MiniRobotLanguage (MRL)

 

BIT.AND

Use logical AND with Bits

 

 

Intention

 

AND returns TRUE (non-zero) if (and only if) the Bits in P1 AND P2 are "1".

Therefore AND masks clear selected bits of P1 without affecting the other bits.

For example, to clear the most-significant (leftmost) 2 bits in the integer value &H9700, AND it with &H3FFF.  

That is, the mask contains all 1s, except for the bit positions you want to force to 0:

 

The parameters P1 and P2 can be given as value or as "binary".

You can choose whether P3 will be "as value" or "as binary". If you do not specify whether "b" or "v" the result will take the format of P1.

Using P4 you can decide how many Bytes the result should have, 8, 16 or 32 bit.

 

Please see ! Smart Package Robot 's BIT. - Operations

 

 

VAN.$$LEA=1

VAN.$$P01=&H1

VAN.$$P02=129

BIT.AND|$$P01|$$P02|$$P03

BIT.Show|v$$P03|$$ERA|$$LEA

MBX.$$P01 AND $$P02 is $$P03$crlf$Bin: $$ERA

ENR.

 

BIT_AND

 

 

 

 

 

Syntax

 

BIT.AND|[b/v]P1|[b/v]P2[|P3][|P4]

 

 

 

Parameter Explanation

 

P1 - Variable containing a value or binary number. For example take the Number "9". It can be an ASC-Code "9" or the numeric number "9".

    You can define this with a prefix of "v" for value and "b" for "binary". If the prefix is omitted, "v" is the default setting for P1.

 

P2 - Variable containing a value or binary number. For example take the Number "9". It can be an ASC-Code "9" or the numeric number "9".

    You can define this with a prefix of "v" for value and "b" for "binary". If the prefix is omitted, "v" is the default setting for P2.

 

P3  - optional,Variable for result. You can define with a prefix of "v" for value and "b" for "binary" the format of the result. If the prefix is omitted the result will have the format of P1.

   If the P3 is "-" then result is placed on the TOS.

 

P4 - optional, can be 1,2 or 4. Number of Bytes that are used internally. The number of Bits is the number of Bytes times 8.

    1 - 8 Bits

    2 - 16 Bits

    4 - 32 Bits

   

    Do not use the "8" Option. See Limitations below.

 

 

Example

 

'*****************************************************

' EXAMPLE 1:

'*****************************************************

VAN.$$LEA=1

VAN.$$P01=&H1

VAN.$$P02=129

BIT.AND|$$P01|$$P02|$$P03

BIT.Show|v$$P03|$$ERA|$$LEA

MBX.$$P01 AND $$P02 is $$P03$crlf$Bin: $$ERA

ENR.

 

 

Remarks

-

 

 

Limitations:

 When using the "|8" Parameter, the lower 4 bits are possibly wrong. This is not a bug its due to the way variables are stored internally.

 Therefore we recommend to not use this option.

 

 

See also:

 

3.5 Hexadezimal, Decimal and Binary and more

VTH. - Variable to Hexadecimal

VDC. - Variable Decrement

CAL. - mathematical CALculation

VAR. - Variable Set Value/Clear

VAN. - Variable Numeric

! Smart Package Robot 's BIT. - Operations

BIT.16to8 - Split 1 Word into 2 Bytes

BIT.16to32 - concatenate 2 Words to 32 Bit DWord

BIT.32to16 - Split 1 DWord into 2 Words

BIT.8to16 - concatenate 2 Bytes to 16 Bit Word

BIT.AND - Use logical AND with Bits

BIT.Clear - Set Bit to 0

BIT.LShift - Shift Bits to Left, insert 0

BIT.NOT - Use logical NOT with Bits

BIT.OR - Use logical OR with Bits

BIT.RotateLeft - Rotate Bits Left

BIT.RotateRight - Rotate Bits Right

BIT.RShift - Shift Bits to Right, insert 0

BIT.Set - Set Bit to 1

BIT.Show - Show Bits in Binary-Numbers

BIT.Store - Set Bit to 1 or 0

BIT.ToBin - change Parameter to Binary-Format

BIT.Toggle - Switch Bit

BIT.ToVal - change Parameter to Value-Format

BIT.XOR - Use logical XOR with Bits

BIT.Get - check if Bit is set

    VDC. - Variable Decrement

    CAL. - mathematical CALculation

    VAR. - Variable Set Value/Clear

    VAN. - Variable Numeric