2020-05-26 04:10:05 +08:00
|
|
|
/**
|
|
|
|
* @file
|
2020-06-06 00:20:37 +08:00
|
|
|
* \brief Program to compute the [QR
|
|
|
|
* decomposition](https://en.wikipedia.org/wiki/QR_decomposition) of a given
|
|
|
|
* matrix.
|
2020-06-07 02:51:49 +08:00
|
|
|
* \author [Krishna Vedala](https://github.com/kvedala)
|
2020-05-26 04:10:05 +08:00
|
|
|
*/
|
|
|
|
|
2020-04-21 00:07:19 +08:00
|
|
|
#include <math.h>
|
2020-05-30 04:23:24 +08:00
|
|
|
#include <stdio.h>
|
2020-04-21 00:07:19 +08:00
|
|
|
#include <stdlib.h>
|
2020-05-30 00:34:58 +08:00
|
|
|
#include <time.h>
|
2020-06-28 23:25:37 +08:00
|
|
|
#include "qr_decompose.h"
|
2020-04-21 00:07:19 +08:00
|
|
|
|
2020-05-26 04:10:05 +08:00
|
|
|
/**
|
2020-05-26 05:02:45 +08:00
|
|
|
* main function
|
2020-05-26 04:10:05 +08:00
|
|
|
*/
|
2020-04-21 00:07:19 +08:00
|
|
|
int main(void)
|
|
|
|
{
|
2020-05-26 04:10:05 +08:00
|
|
|
double **A;
|
|
|
|
unsigned int ROWS, COLUMNS;
|
|
|
|
|
|
|
|
printf("Enter the number of rows and columns: ");
|
|
|
|
scanf("%u %u", &ROWS, &COLUMNS);
|
|
|
|
if (ROWS < COLUMNS)
|
|
|
|
{
|
2020-06-28 23:25:37 +08:00
|
|
|
fprintf(stderr,
|
|
|
|
"Number of rows must be greater than or equal to "
|
|
|
|
"number of columns.\n");
|
2020-05-26 04:10:05 +08:00
|
|
|
return -1;
|
|
|
|
}
|
|
|
|
|
|
|
|
printf("Enter matrix elements row-wise:\n");
|
|
|
|
|
|
|
|
A = (double **)malloc(ROWS * sizeof(double *));
|
|
|
|
for (int i = 0; i < ROWS; i++)
|
|
|
|
A[i] = (double *)malloc(COLUMNS * sizeof(double));
|
|
|
|
|
|
|
|
for (int i = 0; i < ROWS; i++)
|
2020-06-28 23:25:37 +08:00
|
|
|
for (int j = 0; j < COLUMNS; j++) scanf("%lf", &A[i][j]);
|
2020-04-21 00:07:19 +08:00
|
|
|
|
|
|
|
print_matrix(A, ROWS, COLUMNS);
|
|
|
|
|
2020-05-26 04:10:05 +08:00
|
|
|
double **R = (double **)malloc(sizeof(double *) * ROWS);
|
|
|
|
double **Q = (double **)malloc(sizeof(double *) * ROWS);
|
2020-04-21 00:07:19 +08:00
|
|
|
if (!Q || !R)
|
|
|
|
{
|
|
|
|
perror("Unable to allocate memory for Q & R!");
|
|
|
|
return -1;
|
|
|
|
}
|
|
|
|
for (int i = 0; i < ROWS; i++)
|
|
|
|
{
|
|
|
|
R[i] = (double *)malloc(sizeof(double) * COLUMNS);
|
2020-05-26 04:10:05 +08:00
|
|
|
Q[i] = (double *)malloc(sizeof(double) * ROWS);
|
2020-04-21 00:07:19 +08:00
|
|
|
if (!Q[i] || !R[i])
|
|
|
|
{
|
|
|
|
perror("Unable to allocate memory for Q & R.");
|
|
|
|
return -1;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2020-05-30 00:34:58 +08:00
|
|
|
clock_t t1 = clock();
|
2020-04-21 00:07:19 +08:00
|
|
|
qr_decompose(A, Q, R, ROWS, COLUMNS);
|
2020-05-30 00:34:58 +08:00
|
|
|
double dtime = (double)(clock() - t1) / CLOCKS_PER_SEC;
|
2020-04-21 00:07:19 +08:00
|
|
|
|
2020-05-26 04:10:05 +08:00
|
|
|
print_matrix(R, ROWS, COLUMNS);
|
|
|
|
print_matrix(Q, ROWS, COLUMNS);
|
2020-04-21 00:07:19 +08:00
|
|
|
printf("Time taken to compute: %.4g sec\n", dtime);
|
|
|
|
|
|
|
|
for (int i = 0; i < ROWS; i++)
|
|
|
|
{
|
2020-05-26 04:10:05 +08:00
|
|
|
free(A[i]);
|
2020-04-21 00:07:19 +08:00
|
|
|
free(R[i]);
|
|
|
|
free(Q[i]);
|
|
|
|
}
|
2020-05-26 04:10:05 +08:00
|
|
|
free(A);
|
2020-04-21 00:07:19 +08:00
|
|
|
free(R);
|
|
|
|
free(Q);
|
|
|
|
return 0;
|
2020-06-07 02:51:49 +08:00
|
|
|
}
|