From d03c9c665b9e8fbdf86759f32435dc8e61441857 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Fran=C3=A7ois=20Coppens?= Date: Wed, 3 Feb 2021 14:49:13 +0100 Subject: [PATCH] Update of A0_inv fixed. matMul(...) breaks link between A0_inv and Slater_inv. Fixed by creating a new pointer that points to where Slater_inv points to before it gets reassigned by matMul(...) and then copy the updated elements back to the passed array pointed to by the new pointer. --- Helpers.hpp | 19 +++++++++--------- SM-MaponiA3.cpp | 51 ++++++++++++++++++++++++++----------------------- main.cpp | 1 - 3 files changed, 36 insertions(+), 35 deletions(-) diff --git a/Helpers.hpp b/Helpers.hpp index a81e38a..646ba6e 100644 --- a/Helpers.hpp +++ b/Helpers.hpp @@ -25,7 +25,7 @@ void showScalar(T scalar, string name) { } template -void showVector(T* vector, unsigned int size, string name) { +void showVector(T *vector, unsigned int size, string name) { cout << name << " = " << endl; for (unsigned int i = 0; i < size; i++) { cout << "[ " << vector[i] << " ]" << endl; @@ -34,7 +34,7 @@ void showVector(T* vector, unsigned int size, string name) { } template -void showMatrix(T** matrix, unsigned int size, string name) { +void showMatrix(T **matrix, unsigned int size, string name) { cout << name << " = " << endl; for (unsigned int i = 0; i < size; i++) { cout << "[ "; @@ -47,7 +47,7 @@ void showMatrix(T** matrix, unsigned int size, string name) { } template -void showMatrixT(T** matrix, unsigned int size, string name) { +void showMatrixT(T **matrix, unsigned int size, string name) { cout << name << " = " << endl; for (unsigned int i = 0; i < size; i++) { cout << "[ "; @@ -60,8 +60,8 @@ void showMatrixT(T** matrix, unsigned int size, string name) { } template -T** matMul(T** A, T** B, unsigned int size) { - T** C = new T*[size]; +T **matMul(T **A, T **B, unsigned int size) { + T **C = new T*[size]; for (unsigned int i = 0; i < size; i++) { C[i] = new T[size]; } @@ -72,13 +72,12 @@ T** matMul(T** A, T** B, unsigned int size) { } } } - showMatrix(C, size, "C"); return C; } template -T1** outProd(T1* vec1, T2* vec2, unsigned int size) { - T1** C = new T1*[size]; +T1 **outProd(T1 *vec1, T2 *vec2, unsigned int size) { + T1 **C = new T1*[size]; for (unsigned int i = 0; i < size; i++) { C[i] = new T1[size]; } @@ -91,9 +90,9 @@ T1** outProd(T1* vec1, T2* vec2, unsigned int size) { } template -T matDet(T** A, unsigned int M) { +T matDet(T **A, unsigned int M) { int det = 0, p, h, k, i, j; - T** temp = new T*[M]; + T **temp = new T*[M]; for (int i = 0; i < M; i++) temp[i] = new T[M]; if(M == 1) { return A[0][0]; diff --git a/SM-MaponiA3.cpp b/SM-MaponiA3.cpp index 207682a..df94ef2 100644 --- a/SM-MaponiA3.cpp +++ b/SM-MaponiA3.cpp @@ -7,20 +7,15 @@ void Sherman_Morrison(int **Slater0, double **Slater_inv, unsigned int *Dim, unsigned int *N_updates, int **Updates, unsigned int *Updates_index) { unsigned int k, l, lbar, i, j, tmp, M = *Dim; unsigned int *p = new unsigned int[M+1]; - double *breakdown = new double[M+1]; + unsigned int **Id = new unsigned int*[M]; double alpha, beta; - - for (i = 0; i < M+1; i++) { - p[i] = i; - } - - int **Id = new int*[M]; - for (i = 0; i < M; i++) Id[i] = new int[M]; + double **U, *breakdown = new double[M+1]; + double **Al = new double*[M]; + p[0] = 0; for (i = 0; i < M; i++) { - for (j = 0; j < M; j++) { - if (i != j) Id[i][j] = 0; - else Id[i][j] = 1; - } + p[i+1] = i + 1; + Id[i] = new unsigned int[M]; + Al[i] = new double[M]; } // Declare auxiliary solution matrix ylk @@ -31,6 +26,15 @@ void Sherman_Morrison(int **Slater0, double **Slater_inv, unsigned int *Dim, uns ylk[l][k] = new double[M+1]; } } + + // Initialize identity matrix + for (i = 0; i < M; i++) { + for (j = 0; j < M; j++) { + if (i != j) Id[i][j] = 0; + else Id[i][j] = 1; + } + } + // Initialize ylk with zeros for (l = 0; l < M; l++) { for (k = 0; k < M+1; k++) { @@ -73,10 +77,11 @@ void Sherman_Morrison(int **Slater0, double **Slater_inv, unsigned int *Dim, uns } // Construct A-inverse from A0-inverse and the ylk - double **U; - double **Al = new double*[M]; - for (i = 0; i < M; i++) Al[i] = new double[M]; - + // Keep the memory location of the passed array 'Slater_inv' before 'Slater_inv' + // gets reassigned by 'matMul(...)' in the next line, by creating a new + // pointer 'copy' that points to whereever 'Slater_inv' points to now. + double **copy = Slater_inv; + for (l = 0; l < M; l++) { k = l+1; U = outProd(ylk[l][p[k]], Id[p[k]-1], M); @@ -86,23 +91,21 @@ void Sherman_Morrison(int **Slater0, double **Slater_inv, unsigned int *Dim, uns Al[i][j] = Id[i][j] - U[i][j] / beta; } } - showMatrix(Slater_inv, M, "Slater_inv"); Slater_inv = matMul(Al, Slater_inv, M); - showMatrix(Slater_inv, M, "Slater_inv"); } - delete [] p, breakdown; - + // Assign the new values of 'Slater_inv' to the old values in 'copy[][]' for (i = 0; i < M; i++) { - delete [] Id[i]; - delete [] U[i]; - delete [] Al[i]; + for (j = 0; j < M; j++) { + copy[i][j] = Slater_inv[i][j]; + } } for (l = 0; l < M; l++) { for (k = 0; k < M+1; k++) { delete [] ylk[l][k]; } - delete [] ylk[l]; + delete [] ylk[l], Id[l], U[l], Al[l], Slater_inv[l]; } + delete [] p, breakdown; } \ No newline at end of file diff --git a/main.cpp b/main.cpp index 7853531..55af456 100644 --- a/main.cpp +++ b/main.cpp @@ -66,7 +66,6 @@ int main() { unsigned int *dim = new unsigned int(M); unsigned int *n_updates = new unsigned int(M); Sherman_Morrison(A0, A0_inv, dim, n_updates, Ar, Ar_index); - showMatrix(A0_inv, M, "A0_inv"); // Deallocate all vectors and matrices