-
Notifications
You must be signed in to change notification settings - Fork 7
/
Copy pathpiecewiseLinear.m
60 lines (48 loc) · 1.68 KB
/
piecewiseLinear.m
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
function [y] = piecewiseLinear(varargin)
% % piecewiseLinear(tpoints,ypoints,t) or piecewiseLinear([tpoints;ypoints],y)
% evaluates a piecewise linear function with nodes at (tpoints,ypoints) at
% time(s) t
% Copyright 2015-2016 David Ochsenbein
% Copyright 2012-2014 David Ochsenbein, Martin Iggland
%
% This file is part of CAT.
%
% CAT is free software: you can redistribute it and/or modify
% it under the terms of the GNU General Public License as published by
% the Free Software Foundation version 3 of the License.
%
% CAT is distributed in the hope that it will be useful,
% but WITHOUT ANY WARRANTY; without even the implied warranty of
% MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
% GNU General Public License for more details.
%
% You should have received a copy of the GNU General Public License
% along with this program. If not, see <http://www.gnu.org/licenses/>.
if nargin == 3
tpoints = varargin{1}; tpoints = tpoints(:);
ypoints = varargin{2}; ypoints = ypoints(:);
t = varargin{3};
elseif nargin == 2
tpoints = varargin{1}(1,:); tpoints = tpoints(:);
ypoints = varargin{1}(2,:); ypoints = ypoints(:);
t = varargin{2};
end
if ~issorted(tpoints)
warning('piecewiseLinear:unsortedTime',...
'Your PWL profile has an unsorted time');
end
t(t<tpoints(1) & t>=tpoints(1)-1e-5) = tpoints(1);
tpoints = tpoints(:);
ypoints = ypoints(:);
t = t(:);
% find slopes between points
m = diff(ypoints)./diff(tpoints);
% find abscissa
a = ypoints(1:end-1)-m.*tpoints(1:end-1);
for i = 1:length(t)
I(i)=find(t(i)>=tpoints,1,'last');
end
I(I==length(ypoints)) = length(ypoints)-1;
a = a(I);m = m(I);
y = a(:)+m(:).*t;
y = reshape(y,size(t));