Получите биты в определенных положениях
Примите во внимание следующие неподписанные 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, включительно. 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
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. По иным вопросам, например если надо исправить заблокированное для перевода слово, обратитесь к редакторам через форму технической поддержки.