-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathmaxresfun.m
66 lines (65 loc) · 2.25 KB
/
maxresfun.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
61
62
63
64
65
66
%Author: Zsolt T. Kosztyan Ph.D habil., University of Pannonia,
%Faculty of Economics, Department of Quantitative Methods
%----------------
%Calculate maximum resource demands
%----------------
%Output:
%rMAX: is an nR by 1 vector of maximum resource demands
%----------------
%Inputs:
%SST: N by 1 vector of Scheduled Start Time
%DSM: N by N binary upper triangular matrix of the logic domain
%T is an N by 1 vector of task durations
%R is an N by nR matrix of resource demands
%----------------
%Usage:
%rMAX=maxresfun(SST,DSM,T,R)
%----------------
%Example:
%DSM=round(triu(rand(10))); %Generate logic domain
%T=rand(10,1)*20; %Generate logic domain
%[~,EST]=tptfast(DSM,T); %Calculate Early Start Times
%R=rand(10,3)*5; %Generate resource demands (nR=3)
%rMAX=maxresfun(EST,DSM,T,R) %Clculate maximum resource demands for the
% %three resources
%----------------
%Prepositions and Requirements:
%1.) DSM matrix must be a binary upper triangular matrix
%2.) SST,T should be a positive vector, R should be a positive matrix.
function rMAX=maxresfun(SST,DSM,T,R)
N=numel(SST); %Number of tasks
DSM=round(triu(DSM)); %DSM must be an upper triangular binary matrix.
DSM(diag(DSM)==0,:)=0; %Excluded task has no dependency
DSM(:,diag(DSM)==0)=0; %Excluded task has no dependency
T(diag(DSM)==0)=0; %Excluded task has no time demands
R(diag(DSM)==0,:)=0; %Excluded task has no resources
R(isnan(R))=0;
SST(diag(DSM)==0)=0; %Excluded task's start time is zero
SST=reshape(SST,N,1); %%SST should be a column vector
n=numel(T); %Number of elements in vector T
%Initialisation
SFT=SST+T;
%Forward pass
for i=1:(n-1)
for j=(i+1):n
if DSM(i,i)>0
if DSM(j,j)>0
if DSM(i,j)>0 %If there is a dependency between task i and
%task j...
if SST(j)<SFT(i)
SST(j)=SFT(i);
SFT(j)=SST(j)+T(j);
end
end
end
end
end
end
BP=sort(union(SST,SFT)); %Breakpoints, where the resource demands should
%be recalculated
b=numel(BP); %number of breakpoints
B=((repmat(SST,1,b)<=repmat(BP',N,1))&(repmat(SFT,...
1,b)>repmat(BP',N,1)))';
RESFUNC=mtimes(double(B),R);
%RESFUNC=mtimes(B,R); %Calculate resource function
rMAX=max(RESFUNC)';