keep msb vs keep lsb maths(fixed point toolbox)

12 ビュー (過去 30 日間)
fit institute
fit institute 2011 年 3 月 15 日
回答済み: Andy Bartlett 2025 年 5 月 13 日
what is the difference between keep msb maths and keep lsb maths in matlab

回答 (2 件)

TED MOSBY
TED MOSBY 2025 年 5 月 9 日
Hi,
In MATLAB’s Fixed‑point designer the terms Keep MSB (keep most‑significant bits) and Keep LSB (keep least‑significant bits) appear in the fimath object settings for SumMode and ProductMode.
They tell MATLAB how to squeeze a full‑precision result back into a shorter word‑length when you don’t choose full‑precision arithmetic.
  • Keep MSB drops low‑order bits and shortens the fraction length so that all necessary integer bits fit; no overflow occurs.
  • Keep LSB keeps the binary‑point position, preserving the fractional resolution, and simply lets any excess high‑order bits fall off.
Here's the link for the function fimath:
Hope this helps!

Andy Bartlett
Andy Bartlett 2025 年 5 月 13 日
Keep-Most-Significant-Bits vs Keep-Least-Significant Bits vs Full-Precision
Let's consider three different fimath settings.
  • One configured to Keep the 32 Most Significant Bits (MSBs) of Products and Sum
  • One configured to Keep the 32 Least Significant Bits (LSBs) of Products and Sum
  • The default which returns Full Precision Products and Sums
fmMS32Bits = fimath('RoundingMethod', 'Floor', ...
'OverflowAction', 'Wrap', ...
'ProductMode', 'KeepMSB', ...
'ProductWordLength', 32, ...
'SumMode', 'KeepMSB', ...
'SumWordLength', 32, ...
'CastBeforeSum', true);
fmLS32Bits = fimath('RoundingMethod', 'Floor', ...
'OverflowAction', 'Wrap', ...
'ProductMode', 'KeepLSB', ...
'ProductWordLength', 32, ...
'SumMode', 'KeepLSB', ...
'SumWordLength', 32, ...
'CastBeforeSum', true);
fmDefault = fimath
fmDefault =
RoundingMethod: Nearest OverflowAction: Saturate ProductMode: FullPrecision SumMode: FullPrecision
32 Bit Full Precision Example
Now let's apply this to multiplying two 16 bit fixed-point values.
  • When multiplying two 16 bit values, the full precision answer is 32 bits.
  • Keeping the 32 MSBs of a 32 bit full precision result just keeps the whole thing
  • Keeping the 32 LSBs of a 32 bit full precision result just keeps the whole thing
So the results are identical in all three cases. As in this example, where the first two rows are the multiplicands and the last three rows are the FullPrecision, Keep32MSB, and Keep32LSB products, respectively.
% Type Real World Notation: Binary Point
% Value
% numerictype(0,16,2) 13672.25 = 11010101101000.01
% numerictype(0,16,10) 54.5986328125 = 110110.1001100101
% numerictype(0,32,12) 746486.15747070312 = 10110110001111110110.001010000101
% numerictype(0,32,12) 746486.15747070312 = 10110110001111110110.001010000101
% numerictype(0,32,12) 746486.15747070312 = 10110110001111110110.001010000101
48 Bit Full Precision Example
More interesting is a case of multiplying a 32 bit value by a 16 bit value.
  • When multiplying 32 bits by 16 bit values, the full precision answer is 48 bits.
  • Keeping the 32 MSBs of a 48 bit full precision result drops the 16 LSBs
  • Keeping the 32 LSBs of a 48 bit full precision result drops the 16 MSBs
When KeepMSB requires dropping LSBs the Rounding Method matters, for the case of Floor as configured above the LSBs are just thrown away and the remaining bits are not affected. If a different rounding method was selected, then one may be added to the remaining stored integer bits if rounding up is called for.
When KeepLSB requires dropping MSBs the Overflow Action matters, for the case of Wrap as configured above the MSBs are just thrown away and the remaining bits are not affected. If Saturation was used instead, then in the case of an overflow like this example the output would be very different.
% Type Real World Notation: Binary Point
% Value
% numerictype(0,32,18) 13672.211227416992 = 11010101101000.001101100001001100
% numerictype(0,16,10) 54.5986328125 = 110110.1001100101
% numerictype(0,48,28) 746484.04054068029 = 10110110001111110100.0000101001100000110111111100
% numerictype(0,32,12) 746484.04052734375 = 10110110001111110100.000010100110
% numerictype(0,32,28) 4.0405406802892685 = 0100.0000101001100000110111111100
Common Practices
  • A key reason not to use Full-Precision is to reduce the costs on the embedded system of big word lengths
  • KeepMSB is generally better when handling approximations of the real world values of engineering signals, like the examples above.
  • KeepLSB is generally better when you are just doing math on indices and you are confident the indicies will not overflow the KeepLSB bit limit you've specified.
  • You'll often have good engineering reasons to go beyond the simple rules of FullPrecision, KeepMSB, and KeepLSB. Using fimath and other techniques, you can control exactly what range bits are dropped and what precision bits are dropped to match the needs of your design.
Example MATLAB Code
wordLengthA = 32;
wordLengthB = 16;
format compact
format long
a = fi(17*pi*2^8,0,wordLengthA)
a =
1.367221122741699e+04 DataTypeMode: Fixed-point: binary point scaling Signedness: Unsigned WordLength: 32 FractionLength: 18
b = fi(exp(4),0,wordLengthB)
b =
54.598632812500000 DataTypeMode: Fixed-point: binary point scaling Signedness: Unsigned WordLength: 16 FractionLength: 10
prodFullPrecision = a * b
prodFullPrecision =
7.464840405406803e+05 DataTypeMode: Fixed-point: binary point scaling Signedness: Unsigned WordLength: 48 FractionLength: 28
prodMS32Bits = mulWithFiMath(a,b,fmMS32Bits)
prodMS32Bits =
7.464840405273438e+05 DataTypeMode: Fixed-point: binary point scaling Signedness: Unsigned WordLength: 32 FractionLength: 12
prodLS32Bits = mulWithFiMath(a,b,fmLS32Bits)
prodLS32Bits =
4.040540680289268 DataTypeMode: Fixed-point: binary point scaling Signedness: Unsigned WordLength: 32 FractionLength: 28
function y = mulWithFiMath(a,b,fm)
temp = setfimath(a,fm) * setfimath(b,fm);
y = removefimath(temp);
end

カテゴリ

Help Center および File ExchangeFixed-Point Designer についてさらに検索

Community Treasure Hunt

Find the treasures in MATLAB Central and discover how the community can help you!

Start Hunting!

Translated by