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
|
// Scilab ( http://www.scilab.org/ ) - This file is part of Scilab
// Copyright (C) 2002-2004 - INRIA - Vincent COUVERT
//
// This file must be used under the terms of the CeCILL.
// This source file is licensed as described in the file COPYING, which
// you should have received as part of this distribution. The terms
// are also available at
// http://www.cecill.info/licences/Licence_CeCILL_V2-en.txt
function repm=mtlb_repmat(M,m,n)
// Emulation function for repmat() Matlab function
str=%f
if type(M)==10 then
str=%t
M=asciimat(M)
end
if ~isreal(m) then
m=real(m)
end
if or(type(M)==[4,6]) then
M=bool2s(M)
end
rhs=argn(2)
// repmat(M,m) -> repmat(M,m,m)
if rhs==2 then
n=m
end
// repmat(M,[m,n,p,...])
if rhs==2 & size(m,"*")<>1 then
tmp=list()
for k=1:size(m,"*")
tmp(k)=m(k)
end
repm=ones(tmp(1:$)).*.M
// repmat(M,m,n)
else
if ~isreal(n) then
n=real(n)
end
if or(type(n)==[4,6]) then
n=bool2s(n)
end
repm=ones(m,n).*.M
end
if str then
repm=asciimat(repm)
end
endfunction
|