exponenta event banner

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, включительно. 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++ с помощью MATLAB ® Coder™

.

См. также

| | | |

Представлен до R2006a