diff --git a/Homework/Week1/laff_dot.m b/Homework/Week1/laff_dot.m new file mode 100644 index 0000000..ed2e712 --- /dev/null +++ b/Homework/Week1/laff_dot.m @@ -0,0 +1,50 @@ +## 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 . + +## Author: julien Lengrand-Lambert +## Created: 2018-05-03 +function [ alpha ] = laff_dot (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 + + 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 + + alpha = 1; + +endfunction \ No newline at end of file diff --git a/Homework/Week1/test_dot.m b/Homework/Week1/test_dot.m new file mode 100755 index 0000000..0f37a9e --- /dev/null +++ b/Homework/Week1/test_dot.m @@ -0,0 +1,95 @@ +% Create some vectors +x = [ +1 +2 +3 +] +y = [ +0 +-1 +-2 +] +z = [ +4 +3 +2 +1 +] + +% test dot product of column vector with column vector +disp( 'dot product of column vector with column vector' ) +if ( isequal( laff_dot( x, y ), x' * y ) ) + disp( 'TEST PASSED' ) +else + disp( 'TEST FAILED' ) +end + +disp( ' ' ) + +% test dot product of column vector with row vector +disp( 'dot product of column vector with row vector' ) +if ( isequal( laff_dot( x, y' ), x' * y ) ) + disp( 'TEST PASSED' ) +else + disp( 'TEST FAILED' ) +end + +disp( ' ' ) + +% test dot product of row vector with column vector +disp( 'dot product of row vector with column vector' ) +if ( isequal( laff_dot( x', y ), x' * y ) ) + disp( 'TEST PASSED' ) +else + disp( 'TEST FAILED' ) +end + +disp( ' ' ) + +% test dot product of row vector with row vector +disp( 'dot product of row vector with row vector' ) +if ( isequal( laff_dot( x', y' ), x' * y ) ) + disp( 'TEST PASSED' ) +else + disp( 'TEST FAILED' ) +end + +disp( ' ' ) + +% test dot product of column vector with column vector (wrong size) +disp( 'dot product of column vector with column vector (wrong size)' ) +if ( isequal( laff_dot( x, z ), 'FAILED' ) ) + disp( 'TEST PASSED' ) +else + disp( 'TEST FAILED' ) +end + +disp( ' ' ) + +% test dot product of column vector with row vector (wrong size) +disp( 'dot product of column vector with row vector (wrong size)' ) +if ( isequal( laff_dot( x, z' ), 'FAILED' ) ) + disp( 'TEST PASSED' ) +else + disp( 'TEST FAILED' ) +end + +disp( ' ' ) + +% test dot product of row vector with column vector (wrong size) +disp( 'dot product of row vector with column vector (wrong size)' ) +if ( isequal( laff_dot( x', z ), 'FAILED' ) ) + disp( 'TEST PASSED' ) +else + disp( 'TEST FAILED' ) +end + +disp( ' ' ) + +% test dot product of row vector with row vector (wrong size) +disp( 'dot product of row vector with row vector (wrong size)' ) +if ( isequal( laff_dot( x', z' ), 'FAILED' ) ) + disp( 'TEST PASSED' ) +else + disp( 'TEST FAILED' ) +end \ No newline at end of file diff --git a/README.md b/README.md new file mode 100644 index 0000000..56e1f78 --- /dev/null +++ b/README.md @@ -0,0 +1,14 @@ +# LAFF: Linear Algebra - Foundations to Frontiers + +This repo contains code that is used to follow the [LAFF: Linear Algebra - Foundations to Frontiers](https://www.edx.org/course/laff-linear-algebra-foundations-to-frontiers) course on [edx](https://www.edx.org/). + +Most of the code is given at the beginning of the course. + +The code I have written myself is located in the **Homework** folder. + +## Running things + +You will need [Matlab](https://matlab.mathworks.com/) or [Octave](https://octave.org/) to run things + +Personally, I used the Octave CLI and [Microsoft Code](https://code.visualstudio.com/) with the [Octave plugin](https://marketplace.visualstudio.com/items?itemName=toasty-technologies.octave). +