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
|
function [tree]=sci_size(tree)
// Copyright INRIA
// M2SCI function
// Conversion function for Matlab size()
// Input: tree = Matlab funcall tree
// Ouput: tree = Scilab equivalent for tree
// Emulation function: mtlb_size()
// V.C.
// In Matlab : size('str1') = [1 4] but in Scilab : size('str1') = [1 1]
// so we convert expr to ascii code matrix which have good size
// m = size(X,dim) (If two inputs, then only one output)
if rhs==2 then
[X,dim]=getrhs(tree)
if or(X.vtype==[String,Unknown]) then
X = convert2double(X)
end
tree.rhs=Rhs(X,dim)
// Matlab can work with dim > size(size(X),2) but not Scilab
if typeof(dim)=="cste" then
if dim.value>size(X.dims) then
set_infos(["M2SCI found: "+expression2code(dim)+" > size(size("+expression2code(X)+"),2)";
"So result is set to 1"],0)
tree=Cste(1)
else
tree.lhs(1).dims=list(1,1)
tree.lhs(1).type=Type(Double,Real)
end
else
tree=Funcall("mtlb_size",1,list(X,dim),tree.lhs)
tree.lhs(1).dims=list(1,1)
tree.lhs(1).type=Type(Double,Real)
end
// [d1,d2,d3,...,dn] = size(X)
else
X = getrhs(tree)
if or(X.vtype==[String,Unknown]) then
X = convert2double(X)
end
tree.rhs=Rhs(X)
// d1 = size(X)
if lhs==1 then
tree.lhs(1).dims=list(1,size(X.dims))
tree.lhs(1).type=Type(Double,Real)
// [d1,d2,d3,...,dn] = size(X)
else
if size(tree.lhs)<size(X.dims) then
// Number of outputs is less than size(size(X),2) so mtlb_size() is called
tree=Funcall("mtlb_size",size(tree.lhs),list(X),tree.lhs)
end
if size(tree.lhs)>size(X.dims) then
// Number of outputs is greater than size(size(X),2) so mtlb_size() is called
tree=Funcall("mtlb_size",size(tree.lhs),list(X),tree.lhs)
end
for klhs=1:size(tree.lhs)
tree.lhs(klhs).dims=list(1,1)
tree.lhs(klhs).type=Type(Double,Real)
end
end
end
endfunction
|