-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathstirling1.m
121 lines (88 loc) · 3.45 KB
/
stirling1.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
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
function output = stirling1(numormat,a,b)
%Stirling number/matrix of the first kind.
%By: Amir Shakouri
%Date: 22/02/2021
%Help:
%Standard case:
% Input 1: 'matrix' or 'number'
% Input 2: The dimension of the matrix minus one, or
% Stirling number with equal arguments (=1)
% Input 3: A Stirling number with the specified arguments
%Special cases:
% 1) If only the first input is specified: The ouput is the Striling matrix of
% the first kind with the specified dimension
% 2) If only the first two inputs are specified:
% 2-a) If both inputs are numbers, then the output is the
% Stirling number with the specified arguments
% 2-b) If the first input is "matrix", then the output is a
% Stirling matrix with the specified dimension
% 2-c) If the first input is "number", then the ouput the a
% Stirling number with equal arguments (=1)
switch nargin
case 1 %If only the first argument is specified
if ischar(numormat)==1
error('Please specify the second (and third) argument(s).');
else
n=numormat+1;
end
case 2 %If only the first two arguments are specified
if ischar(numormat)==1
switch numormat
case 'number'
nomen=a;
denom=a;
n=a+1;
case 'matrix'
n=a+1;
otherwise
error('If the first input is a character, it should be "number" or "matrix".');
end
else
nomen=numormat;
denom=a;
n=max(nomen,denom)+1;
end
case 3 %If the first three arguments are specified
if ischar(numormat)==1
switch numormat
case 'number'
nomen=a;
denom=b;
n=max(a,b)+1;
case 'matrix'
error('If the first input is "matrix", only one other arguments should be specified.');
otherwise
error('If the first input is a character, it should be "number" or "matrix".');
end
else
error('If the first input is not a character, only two input arguments should be specified.');
end
otherwise
error('Do not specify more than three arguments');
end
s=inv(stirling2(n-1));
S=zeros(n,n);
for i=1:n
for j=1:n
if i>=j
S(i,j)=s(i,j)*(-1)^(i-j);
end
end
end
switch nargin
case 1 %If only the first argument is specified
output=S;
case 2 %If only the first two arguments are specified
if ischar(numormat)==1
switch numormat
case 'number'
output=S(nomen+1,denom+1);
case 'matrix'
output=S;
end
else
output=S(nomen+1,denom+1);
end
case 3 %If the first three arguments are specified
output=S(nomen+1,denom+1);
end