Avoid negative sign with compose() when output is zero, e.g. '-0' or '-0.0'
3 views (last 30 days)
Show older comments
When compose outputs zero, it includes a negative sign if the number was negative, giving, e.g. -0 or -0.0. How can I avoid this? (Other than writing another function that does a string compare for every element output by compose and removes the negative sign if there are only zeros.)
num = -0.04;
compose('%.1f', num)
0 Comments
Accepted Answer
Stephen23
on 20 Feb 2025
num = -0.04;
txt = compose('%.1f', num)
txt = regexprep(txt,'^-(0+(\.0+)?)$','$1')
More Answers (2)
dpb
on 20 Feb 2025
Moved: dpb
on 20 Feb 2025
num = -0.04;
fprintf('%.1f\n', num)
This is the normal and expected behavior when the value is rounded because it IS negative.
Changing it would be deceiving to the user who would then presume it was positive.
But, if one is adamant, then to post process just a string substitution is all that is required since the precision of the output is given, one doesn't have to do anything exotic.
8 Comments
John D'Errico
on 20 Feb 2025
Edited: John D'Errico
on 20 Feb 2025
No, you completely misunderstand me, but perhaps I could have said it differently.
It is a terribly bad idea for MATLAB to do something like that automatically in any way. Those negative numbers were generated by some process, some computation that apparently did something you do not like. That minus sign should be a flag to you that something happened, that there is something down there, NOT just a zero. I'm sorry though. Ignoring a problem, and pretending it does not exist is something serious.
Far better is to understand where they came from, and fix THAT. Fix the problem, rather than patching the symptom.
However, if you want to remove them anyway, without understanding why they happened, then that is YOUR choice to make. All you need do is essentially round those small values up to zero. And that is trivially done, with a simple test. You can write a function that checks for small negatives, and replaces them with zero, and you can do that without any string parsing. Your choice, and not at all difficult to do.
Leon
on 20 Feb 2025
Edited: Leon
on 20 Feb 2025
3 Comments
Stephen23
on 20 Feb 2025
Note that the numeric rounding and the compiled text may diverge from each other, which leads to incorrect outputs for many values:
compose('%.2f', -0.025) % correct
zerocompose('%.2f', -0.025) % wrong
function c = zerocompose(formatSpec, A)
c = compose(formatSpec, A);
for ii = 1:numel(A)
val = A(ii);
str = c{ii};
if str(1) == '-' && round(val) == 0
c{ii} = str(2:end);
end
end
end
See Also
Categories
Find more on Environment and Settings in Help Center and File Exchange
Community Treasure Hunt
Find the treasures in MATLAB Central and discover how the community can help you!
Start Hunting!