bitget

Получите биты в определенных положениях

Синтаксис

Описание

пример

c = bitget(a, bit) возвращает значения бит в положениях, заданных bit в a как беззнаковые целые числа размера слова 1.

Примеры

свернуть все

Примите во внимание следующие неподписанные fi с фиксированной точкой число со значением 85, размер слова 8 и длина дроби 0:

a = fi(85,0,8,0);
disp(bin(a))
01010101

Получите двоичное представление бита в позиции 4:

c = bitget(a,4);

bitget возвращает бит в позиции 4 в двоичном представлении a.

Начните с подписанной матрицы с фиксированной точкой 3 на 3 с размером слова 4 и длиной дроби 0.

a = fi([2 3 4;6 8 2;3 5 1],0,4,0);
disp(bin(a))
0010   0011   0100
0110   1000   0010
0011   0101   0001

Получите двоичное представление бит в заданном положении.

c = bitget(a,fi(2))
c=3×3 object
     1     1     0
     1     0     1
     1     0     0

          DataTypeMode: Fixed-point: binary point scaling
            Signedness: Unsigned
            WordLength: 1
        FractionLength: 0

MATLAB ® возвращает матрицу бит в положении fi(2) от a. Выходная матрица имеет те же размерности, что и a, и размер слова 1.

Начнем со подписанного вектора с фиксированной точкой с размером слова 16, длиной дроби 4.

a = fi([86 6 53 8 1],0,16,4);
disp(bin(a))
0000010101100000   0000000001100000   0000001101010000   0000000010000000   0000000000010000

Создайте вектор, который задает положения бит, которые нужно получить.

bit = [1,2,5,7,4]
bit = 1×5

     1     2     5     7     4

Получите двоичное представление бит a в положениях, указанных в bit.

c = bitget(a,bit)
c=1×5 object
     0     0     1     0     0

          DataTypeMode: Fixed-point: binary point scaling
            Signedness: Unsigned
            WordLength: 1
        FractionLength: 0

bitget возвращает вектор бит a в положениях, указанных в bit. Вектор выхода имеет ту же длину, что и входы, a и bit, и размер слова 1.

Создайте fi по умолчанию объект со значением pi.

a = fi(pi);
disp(bin(a))
0110010010001000

Объект по умолчанию подписан с размером слова 16.

Создайте вектор положений бит, в которые вы хотите попасть aи получите двоичное представление этих бит.

bit = fi([15,3,8,2]);
c = bitget(a,bit)
c=1×4 object
     1     0     1     0

          DataTypeMode: Fixed-point: binary point scaling
            Signedness: Unsigned
            WordLength: 1
        FractionLength: 0

MATLAB ® возвращает вектор бит в a в положениях, заданных вектором индекса, bit.

Входные параметры

свернуть все

Входной массив, заданный как скаляр, вектор, матрица или многомерный массив fi с фиксированной точкой объекты. Если a и bit оба являются нескалярными, они должны иметь одинаковую размерность. Если a имеет numerictype со знаком, битовое представление сохраненного целого числа находится в представлении дополнения двух.

Типы данных: fi с фиксированной точкой

Битовый индекс, заданный как скалярный, векторный, матричный или многомерный массив fi объекты или встроенные типы данных. Если a и bit оба являются нескалярными, они должны иметь одинаковую размерность. bit должно содержать целочисленные значения между 1 и размер слова a, включительно. The LSB (самый правый бит) задается битовым индексом 1 и MSB (самый левый бит) задается размером слова a. bit не обязательно быть вектором последовательных битовых положений; это также может быть переменное значение индекса.

a = fi(pi,0,8);
a.bin
11001001

Типы данных: fi| single | double | int8 | int16 | int32 | int64 | uint8 | uint16 | uint32 | uint64

Выходные аргументы

свернуть все

Выходной массив, заданный как беззнаковый скаляр, вектор, матрица или многомерный массив с WordLength 1.

Если a является массивом и bit является скаляром, c - беззнаковый массив с размером слова 1. Этот неподписанный массив содержит значения бит в положении bit в каждом элементе с фиксированной точкой в a.

Если a является скаляром и bit является массивом, c - беззнаковый массив с размером слова 1. Этот неподписанный массив содержит значения бит в a в положениях, указанных в bit.

Расширенные возможности

Генерация кода C/C + +
Сгенерируйте код C и C++ с помощью Coder™ MATLAB ®

.

См. также

| | | |

Представлено до R2006a
Для просмотра документации необходимо авторизоваться на сайте