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