mirror of
https://github.com/TREX-CoE/Sherman-Morrison.git
synced 2024-12-27 06:43:55 +01:00
Merge pull request #12 from pablooliveira/SMStandard
This commit is contained in:
commit
f352a09815
14
Makefile
14
Makefile
@ -1,16 +1,16 @@
|
|||||||
## Compilers
|
## Compilers
|
||||||
ARCH = -xCORE-AVX2
|
ARCH =
|
||||||
H5CXX = h5c++
|
H5CXX = h5c++
|
||||||
CXX = icpc
|
CXX = clang++
|
||||||
FC = ifort
|
FC = flang
|
||||||
|
|
||||||
## Compiler flags
|
## Compiler flags
|
||||||
H5CXXFLAGS = -O0 -g
|
H5CXXFLAGS = -O0 -g
|
||||||
CXXFLAGS = -O0 -g -traceback
|
CXXFLAGS = -O0 -g
|
||||||
FFLAGS = -O0 -g -traceback
|
FFLAGS = -O0 -g
|
||||||
|
|
||||||
INCLUDE = -I $(INC_DIR)/
|
INCLUDE = -I $(INC_DIR)/
|
||||||
DEPS_CXX = $(OBJ_DIR)/SM_MaponiA3.o
|
DEPS_CXX = $(OBJ_DIR)/SM_MaponiA3.o $(OBJ_DIR)/SM_Standard.o
|
||||||
DEPS_F = $(DEPS_CXX) $(OBJ_DIR)/SM_MaponiA3_mod.o $(OBJ_DIR)/Helpers_mod.o
|
DEPS_F = $(DEPS_CXX) $(OBJ_DIR)/SM_MaponiA3_mod.o $(OBJ_DIR)/Helpers_mod.o
|
||||||
FLIBS = -lstdc++
|
FLIBS = -lstdc++
|
||||||
|
|
||||||
@ -66,6 +66,8 @@ $(OBJ_DIR)/%.o: $(TST_DIR)/%.f90 | $(OBJ_DIR)
|
|||||||
$(OBJ_DIR)/SM_MaponiA3.o: $(SRC_DIR)/SM_MaponiA3.cpp $(INC_DIR)/* | $(OBJ_DIR)
|
$(OBJ_DIR)/SM_MaponiA3.o: $(SRC_DIR)/SM_MaponiA3.cpp $(INC_DIR)/* | $(OBJ_DIR)
|
||||||
$(CXX) $(CXXFLAGS) -fPIC $(ARCH) $(INCLUDE) -c -o $@ $<
|
$(CXX) $(CXXFLAGS) -fPIC $(ARCH) $(INCLUDE) -c -o $@ $<
|
||||||
|
|
||||||
|
$(OBJ_DIR)/SM_Standard.o: $(SRC_DIR)/SM_Standard.cpp $(INC_DIR)/* | $(OBJ_DIR)
|
||||||
|
$(CXX) $(CXXFLAGS) -fPIC $(ARCH) $(INCLUDE) -c -o $@ $<
|
||||||
|
|
||||||
|
|
||||||
#### LINKING
|
#### LINKING
|
||||||
|
@ -35,21 +35,22 @@ void showVector(T *vector, unsigned int size, string name) {
|
|||||||
|
|
||||||
template<typename T>
|
template<typename T>
|
||||||
void showMatrix(T *matrix, unsigned int M, string name) {
|
void showMatrix(T *matrix, unsigned int M, string name) {
|
||||||
cout << name << " = " << endl;
|
cout.precision(17);
|
||||||
|
cout << name << " = [" << endl;
|
||||||
for (unsigned int i = 0; i < M; i++) {
|
for (unsigned int i = 0; i < M; i++) {
|
||||||
cout << "[";
|
cout << "[";
|
||||||
for (unsigned int j = 0; j < M; j++) {
|
for (unsigned int j = 0; j < M; j++) {
|
||||||
if (matrix[i*M + j] >= 0) {
|
if (matrix[i*M + j] >= 0) {
|
||||||
cout << " " << matrix[i*M + j];
|
cout << " " << matrix[i*M + j] << ",";
|
||||||
}
|
}
|
||||||
else {
|
else {
|
||||||
cout << " " << matrix[i*M + j];
|
cout << " " << matrix[i*M + j] << "," ;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
cout << " ]," << endl;
|
||||||
|
}
|
||||||
cout << "]" << endl;
|
cout << "]" << endl;
|
||||||
}
|
}
|
||||||
cout << endl;
|
|
||||||
}
|
|
||||||
|
|
||||||
template<typename T>
|
template<typename T>
|
||||||
T *transpose(T *A, unsigned int M) {
|
T *transpose(T *A, unsigned int M) {
|
||||||
|
3
include/SM_Standard.hpp
Normal file
3
include/SM_Standard.hpp
Normal file
@ -0,0 +1,3 @@
|
|||||||
|
void SM(double *Slater_inv, unsigned int Dim,
|
||||||
|
unsigned int N_updates, double *Updates,
|
||||||
|
unsigned int *Updates_index);
|
@ -55,9 +55,9 @@ void MaponiA3(double *Slater_inv, unsigned int Dim,
|
|||||||
p[lbar] = tmp;
|
p[lbar] = tmp;
|
||||||
component = Updates_index[p[l] - 1];
|
component = Updates_index[p[l] - 1];
|
||||||
beta = 1 + ylk[l - 1][p[l]][component];
|
beta = 1 + ylk[l - 1][p[l]][component];
|
||||||
if (beta == 0) {
|
if (fabs(beta) < 1e-6) {
|
||||||
cout << "Break-down occured. Exiting..." << endl;
|
cout << "Break-down occured. Exiting..." << endl;
|
||||||
exit;
|
exit(1);
|
||||||
}
|
}
|
||||||
for (k = l + 1; k < N_updates + 1; k++) {
|
for (k = l + 1; k < N_updates + 1; k++) {
|
||||||
alpha = ylk[l - 1][p[k]][component] / beta;
|
alpha = ylk[l - 1][p[k]][component] / beta;
|
||||||
|
44
src/SM_Standard.cpp
Normal file
44
src/SM_Standard.cpp
Normal file
@ -0,0 +1,44 @@
|
|||||||
|
// SM-Standard.cpp
|
||||||
|
// Standard Sherman Morrison with multiple updates
|
||||||
|
#include "SM_Standard.hpp"
|
||||||
|
#include "Helpers.hpp"
|
||||||
|
#include <iostream>
|
||||||
|
|
||||||
|
void SM(double *Slater_inv, unsigned int Dim, unsigned int N_updates,
|
||||||
|
double *Updates, unsigned int *Updates_index) {
|
||||||
|
|
||||||
|
double C[Dim];
|
||||||
|
double D[Dim];
|
||||||
|
|
||||||
|
// For each update
|
||||||
|
for (unsigned int l = 0; l < N_updates; l++) {
|
||||||
|
|
||||||
|
// C = A^{-1} x U_l
|
||||||
|
for (unsigned int i = 0; i < Dim; i++) {
|
||||||
|
C[i] = 0;
|
||||||
|
for (unsigned int j = 0; j < Dim; j++) {
|
||||||
|
C[i] += Slater_inv[i * Dim + j] * Updates[l * Dim + j];
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
// Denominator
|
||||||
|
double den = 1 + C[Updates_index[l] - 1];
|
||||||
|
if (den < 1e-6) {
|
||||||
|
std::cerr << "Breakdown condition triggered" << std::endl;
|
||||||
|
}
|
||||||
|
double iden = 1 / den;
|
||||||
|
|
||||||
|
// D = v^T x A^{-1}
|
||||||
|
for (unsigned int j = 0; j < Dim; j++) {
|
||||||
|
D[j] = Slater_inv[(Updates_index[l] - 1) * Dim + j];
|
||||||
|
}
|
||||||
|
|
||||||
|
// A^{-1} = A^{-1} - C x D / den
|
||||||
|
for (unsigned int i = 0; i < Dim; i++) {
|
||||||
|
for (unsigned int j = 0; j < Dim; j++) {
|
||||||
|
double update = C[i] * D[j] * iden;
|
||||||
|
Slater_inv[i * Dim + j] -= update;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
@ -4,10 +4,11 @@
|
|||||||
#include "hdf5/serial/H5Cpp.h"
|
#include "hdf5/serial/H5Cpp.h"
|
||||||
|
|
||||||
#include "SM_MaponiA3.hpp"
|
#include "SM_MaponiA3.hpp"
|
||||||
|
#include "SM_Standard.hpp"
|
||||||
#include "Helpers.hpp"
|
#include "Helpers.hpp"
|
||||||
|
|
||||||
using namespace H5;
|
using namespace H5;
|
||||||
//#define DEBUG 0
|
//#define DEBUG
|
||||||
|
|
||||||
const H5std_string FILE_NAME( "datasets.hdf5" );
|
const H5std_string FILE_NAME( "datasets.hdf5" );
|
||||||
|
|
||||||
@ -62,7 +63,8 @@ int test_cycle(H5File file, int cycle) {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
MaponiA3(slater_inverse, dim, nupdates, updates, col_update_index);
|
//MaponiA3(slater_inverse, dim, nupdates, updates, col_update_index);
|
||||||
|
SM(slater_inverse, dim, nupdates, updates, col_update_index);
|
||||||
|
|
||||||
#ifdef DEBUG
|
#ifdef DEBUG
|
||||||
showMatrix(slater_matrix, dim, "NEW Slater");
|
showMatrix(slater_matrix, dim, "NEW Slater");
|
||||||
|
@ -4,6 +4,7 @@
|
|||||||
#include "hdf5/serial/H5Cpp.h"
|
#include "hdf5/serial/H5Cpp.h"
|
||||||
|
|
||||||
#include "SM_MaponiA3.hpp"
|
#include "SM_MaponiA3.hpp"
|
||||||
|
#include "SM_Standard.hpp"
|
||||||
#include "Helpers.hpp"
|
#include "Helpers.hpp"
|
||||||
|
|
||||||
using namespace H5;
|
using namespace H5;
|
||||||
@ -63,6 +64,7 @@ int test_cycle(H5File file, int cycle) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
MaponiA3(slater_inverse, dim, nupdates, updates, col_update_index);
|
MaponiA3(slater_inverse, dim, nupdates, updates, col_update_index);
|
||||||
|
//SM(slater_inverse, dim, nupdates, updates, col_update_index);
|
||||||
|
|
||||||
#ifdef DEBUG
|
#ifdef DEBUG
|
||||||
showMatrix(slater_matrix, dim, "NEW Slater");
|
showMatrix(slater_matrix, dim, "NEW Slater");
|
||||||
|
Loading…
Reference in New Issue
Block a user