Получить биты в определенных позициях
Рассмотрим следующие неподписанные фиксированные точки 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.
a - Входной массивВходной массив, заданный как скаляр, вектор, матрица или многомерный массив с фиксированной точкой fi объекты. Если a и bit оба не являются скалярными, они должны иметь одинаковую размерность. Если a имеет подпись numerictype, битовое представление сохраненного целого числа находится в представлении дополнения двух.
типы данных: фиксированная точка fi
bit - Битовый индексБитовый индекс, заданный как скаляр, вектор, матрица или многомерный массив 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
c - Выходной массивВыходной массив, заданный как беззнаковый скаляр, вектор, матрица или многомерный массив с WordLength 1.
Если a является массивом и bit является скаляром, c - беззнаковый массив с длиной слова 1. Этот неподписанный массив содержит значения битов в позиции bit в каждом элементе с фиксированной точкой в a.
Если a является скаляром и bit является массивом, c - беззнаковый массив с длиной слова 1. Этот неподписанный массив содержит значения битов в a в положениях, указанных в bit.
Для VHDL ® генерирует оператор среза :a(idx).
Для Verilog ® создает оператор среза :a[idx].
Имеется измененная версия этого примера. Открыть этот пример с помощью изменений?
1. Если смысл перевода понятен, то лучше оставьте как есть и не придирайтесь к словам, синонимам и тому подобному. О вкусах не спорим.
2. Не дополняйте перевод комментариями “от себя”. В исправлении не должно появляться дополнительных смыслов и комментариев, отсутствующих в оригинале. Такие правки не получится интегрировать в алгоритме автоматического перевода.
3. Сохраняйте структуру оригинального текста - например, не разбивайте одно предложение на два.
4. Не имеет смысла однотипное исправление перевода какого-то термина во всех предложениях. Исправляйте только в одном месте. Когда Вашу правку одобрят, это исправление будет алгоритмически распространено и на другие части документации.
5. По иным вопросам, например если надо исправить заблокированное для перевода слово, обратитесь к редакторам через форму технической поддержки.