Files
LAFF/Homework/Week1/laff_copy.m
Julien Lengrand-Lambert bd4b76e1a7 Add laff_copy
2018-05-02 14:23:00 +02:00

56 lines
1.6 KiB
Mathematica

## Copyright (C) 2018 julien Lengrand-Lambert
##
## This program 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; either version 3 of the License, or
## (at your option) any later version.
##
## This program 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/>.
## Author: julien Lengrand-Lambert <jlengrand@juliens-MacBook-Pro.local>
## Created: 2018-04-30
function [ y_out ] = laff_copy (x, y)
y_out = y;
function isVector = isVector(x)
isVector = (size(x, 1) == 1 || size(x, 2) == 1);
endfunction
function isCompatible = isCompatible(x, y)
isCompatible = (isequal(size(x), size(y)) || isequal(size(x), fliplr(size(y))));
endfunction
function needsTranspose = needsTranspose(x, y)
needsTranspose = isequal(size(x) ,(size(y')));
endfunction
if !isVector(x)
disp('Error : x not a vector');
y_out = 'FAILED';
return
end
if !isVector(y)
disp('Error : y not a vector');
y_out = 'FAILED';
return
end
if !isCompatible(x, y)
disp('Error : x and y are not compatible');
y_out = 'FAILED';
return
end
for i = 1:max(size(x))
y_out(i) = x(i);
end
endfunction