Skip to content
/ CM Public

UNIPI: Computational Mathematics for Learning and Data Analysis 2019-2020: Project Omplementation

License

Notifications You must be signed in to change notification settings

steb6/CM

Folders and files

NameName
Last commit message
Last commit date

Latest commit

2be5f22 · Oct 15, 2020

History

94 Commits
Mar 18, 2020
Oct 15, 2020
Oct 14, 2020
Oct 2, 2020
Mar 18, 2020
Oct 13, 2020
Oct 13, 2020
Oct 13, 2020
Oct 13, 2020
Oct 5, 2020
Oct 14, 2020
Oct 14, 2020
Oct 14, 2020
Oct 13, 2020

Repository files navigation

Computational mathematics for learning and data analysis [2019-2020]: project non-ML n°12 implementation

Most significant result

The problem

(P)

is the linear least squares problem minw∥X+w−y∥ where X+ is the matrix obtained by augmenting the (tall thin) matrix X from the ML-cup dataset by prof. Micheli with a few functions of your choice of the features of the dataset, and y is one of the corresponding output vectors. For instance, if X contains columns [x1,x2], you may add functions such as log(x1), x12, x1*x2, …

(A1)

is an algorithm of the class of Conjugate Gradient methods [references: J. Nocedal, S. Wright, Numerical Optimization].

(A2)

is thin QR factorization with Householder reflectors [Trefethen, Bau, Numerical Linear Algebra, Lecture 10], in the variant where one does not form the matrix Q, but stores the Householder vectors uk and uses them to perform (implicitly) products with Q and QT.

No off-the-shelf solvers allowed. In particular you must implement yourself the thin QR factorization, and the computational cost of your implementation should scale linearly with the largest dimension of the matrix X.

How to tun the code

To install the requirements with

pip install -r requirements.txt

To see the results of (A1) applied to (P), execute the Conjugate Gradient method with

python test_cg.py

and for (A2) execute QR factorization method with

python test_qr.py

To test the computational cost of (A1) and (A2) applied to 3 different matrices

  • m=n,
  • m>n
  • m>>n

use

python times.py

this will override the plots

  • square.png
  • little_m.png
  • big_m.png

in the results folder. The numerical results of times.py will be saved in the txt files {method}_{type of matrix}.txt (for example cg_little_m.txt is the Conjugate Gradient applied to the matrix m>n). The format is the following:

  1. the first line are the sizes
  2. the second line are the times

and everything is saved in scientific notation.

About

UNIPI: Computational Mathematics for Learning and Data Analysis 2019-2020: Project Omplementation

Topics

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published