beautypg.com

Shift() – Texas Instruments PLUS TI-89 User Manual

Page 516

background image

Appendix A: Functions and Instructions 499

8992APPA.DOC TI-89 / TI-92 Plus: Appendix A (US English) Susan Gullord Revised: 02/23/01 1:48 PM Printed: 02/23/01 2:21 PM Page 499 of 132

shift()

CATALOG

shift(

integer1

[

,

#ofShifts

]

)

integer

Shifts the bits in a binary integer. You can
enter

integer1

in any number base; it is

converted automatically to a signed, 32-bit
binary form. If the magnitude of

integer1

is

too large for this form, a symmetric modulo
operation brings it within the range.

If

#ofShifts

is positive, the shift is to the left. If

#ofShifts

is negative, the shift is to the right.

The default is ë 1 (shift right one bit).

In a right shift, the rightmost bit is dropped
and 0 or 1 is inserted to match the leftmost
bit. In a left shift, the leftmost bit is dropped
and 0 is inserted as the rightmost bit.

For example, in a right shift:

In Bin base mode:

shift(0b1111010110000110101)
¸

0b111101011000011010

shift(256,1) ¸

0b1000000000

In Hex base mode:

shift(0h78E) ¸

0h3C7

shift(0h78E,ë 2) ¸

0h1E3

shift(0h78E,2) ¸

0h1E38

Important:

To enter a binary or

hexadecimal number, always use the 0b
or 0h prefix (zero, not the letter O).

0b00000000000001111010110000110101

produces:

0b00000000000000111101011000011010

The result is displayed according to the

Base

mode. Leading zeros are not shown.

shift(

list1

[

,

#ofShifts

]

)

list

Returns a copy of

list1

shifted right or left by

#ofShifts

elements. Does not alter

list1

.

If

#ofShifts

is positive, the shift is to the left. If

#ofShifts

is negative, the shift is to the right.

The default is ë 1 (shift right one element).

Elements introduced at the beginning or end
of

list

by the shift are set to the symbol

“undef”.

In Dec base mode:

shift({1,2,3,4}) ¸

{undef 1 2 3}

shift({1,2,3,4},ë 2) ¸

{undef undef 1 2}

shift({1,2,3,4},1) ¸

{2 3 4 undef}

shift(

string1

[

,

#ofShifts

]

)

string

Returns a copy of

string1

shifted right or left

by

#ofShifts

characters. Does not alter

string1

.

If

#ofShifts

is positive, the shift is to the left. If

#ofShifts

is negative, the shift is to the right.

The default is ë 1 (shift right one character).

Characters introduced at the beginning or
end of

string

by the shift are set to a space.

shift("abcd") ¸

" abc"

shift("abcd",ë 2) ¸

" ab"

shift("abcd",1) ¸

"bcd "

Inserts 0 if leftmost bit is 0,

or 1 if leftmost bit is 1.

Each bit shifts right.

Dropped

This manual is related to the following products: