-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathestring.m
More file actions
64 lines (56 loc) · 1.49 KB
/
estring.m
File metadata and controls
64 lines (56 loc) · 1.49 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
function s = estring(x,sigfigs,delim)
%ESTRING Make string with Engineering Unit Exponent
% s = estring(x,sigfigs,delim)
% Converts numbers into strings corresponding to typical engineering
% denominations i.e. 5.3e3 -> 5.3k, 6.0001e-6 -> 6u, etc.
% INPUTS:
% x Input number to be converted
% sigfigs Number of requested significant figures (default 3)
% delim decimal point delimiter (default '.')
%
% Example
% estring(5.3e6,2,'p') returns 5p3M
% estring(6.005e-6,3) returns 6.01u
%
% See also sprintf
% Author: Peter Hollender
% Created: Jan 2011
% Copyright 2011
if ~exist('sigfigs','var')
sigfigs = 3;
end
if ~exist('delim','var')
delim = '.';
end
prefixes = {'y','z','a','f','p','n','u','m','','k','M','G','T','P','E','Z','Y'};
exponents = [-24 -21 -18 -15 -12 -9 -6 -3 0 3 6 9 12 15 18 21 24];
if x<0
sgn = '-';
x = -1*x;
else
sgn = '';
end
i = length(exponents);
while i >= 1 && floor(x*10^-exponents(i))==0
i = i-1;
end
if x==0
if sigfigs <= 1
s = '0';
else
s = ['0' delim repmat('0',1,sigfigs-1)];
end
else
integers = num2str(floor(x*10^-exponents(i)));
l = length(integers);
remainder = x - (10^exponents(i)*floor(x*10^-exponents(i)));
if l>=sigfigs
if remainder * 10^-exponents(i)>=.5
integers = num2str(round(x*10^-exponents(i)));
end
s = [sgn integers prefixes{i}];
else
str = sprintf('%%0%1.0f.0f',sigfigs-l);
s = [sgn integers delim sprintf(str,round(remainder*10^(-exponents(i) + (sigfigs-l)+1))/10) prefixes{i}];
end
end