2022-10-17 14:56:32 +02:00
|
|
|
#pragma once
|
|
|
|
|
2022-07-11 14:48:59 +02:00
|
|
|
#include <math.h>
|
|
|
|
#include <stdio.h>
|
|
|
|
#include <stdint.h>
|
|
|
|
#include <assert.h>
|
|
|
|
#include <stdlib.h>
|
|
|
|
#include <string.h>
|
2022-09-22 14:37:00 +02:00
|
|
|
#include <hdf5/serial/hdf5.h>
|
2022-10-01 18:54:18 +02:00
|
|
|
|
2022-07-11 14:48:59 +02:00
|
|
|
#include "kernels.h"
|
|
|
|
|
|
|
|
typedef struct Error {
|
|
|
|
uint32_t rc;
|
|
|
|
uint64_t error;
|
|
|
|
} Error;
|
|
|
|
|
2022-11-08 15:35:25 +01:00
|
|
|
#ifdef USE_OMP_OFFLOAD_CUDA
|
2022-10-10 11:01:53 +02:00
|
|
|
cublasHandle_t init_cublas();
|
|
|
|
cusolverDnHandle_t init_cusolver();
|
|
|
|
#endif
|
|
|
|
|
2022-10-01 18:54:18 +02:00
|
|
|
void copy(double* Slater_invT_copy, uint64_t Lds, double* tmp, uint64_t Dim);
|
|
|
|
void update(double* slaterT,double* upds, uint64_t* ui, uint64_t nupds,uint64_t Dim, u_int64_t Lds);
|
|
|
|
void convert(double* upds, uint64_t nupds, uint64_t* ui, double* slaterT, uint64_t Dim, u_int64_t Lds);
|
2022-10-17 14:56:32 +02:00
|
|
|
void transpose(double* a, uint16_t lda, double *b, uint16_t ldb, uint16_t m, uint16_t n);
|
2022-10-01 18:54:18 +02:00
|
|
|
double get_determinant(uint32_t cycle, hid_t file_id);
|
|
|
|
double* get_slater_inv(uint32_t cycle, hid_t file_id, uint64_t Dim, u_int64_t Lds);
|
|
|
|
double* get_slater(uint32_t cycle, hid_t file_id, uint64_t Dim, u_int64_t Lds);
|
|
|
|
double* get_upds(uint32_t cycle, hid_t file_id, uint64_t nupds, u_int64_t Lds);
|
|
|
|
uint64_t* get_upd_idcs(uint32_t cycle, hid_t file_id, uint64_t nupds);
|
|
|
|
uint64_t get_dim(uint32_t cycle, hid_t file_id);
|
|
|
|
uint64_t get_nupdates(uint32_t cycle, hid_t file_id);
|
|
|
|
|
|
|
|
//void matmul(double *a, double *b, double *prod, const uint64_t Lds, const uint64_t Dim);
|
2022-07-11 14:48:59 +02:00
|
|
|
void residual(double *a, double *res, const uint64_t Dim);
|
2022-07-22 11:34:29 +02:00
|
|
|
double frobenius_norm2(double *A, const uint64_t Lds, const uint64_t Dim);
|
|
|
|
double frobenius_norm(double *A, const uint64_t Lds, const uint64_t Dim);
|
|
|
|
double max_norm(double *A, const uint64_t Lds, const uint64_t Dim);
|
|
|
|
double condition_number(double *A, double *Ainv, const uint64_t Lds, const uint64_t Dim);
|
2022-07-11 14:48:59 +02:00
|
|
|
void read_uint(hid_t file_id, const char *key, uint64_t *data);
|
|
|
|
void read_double(hid_t file_id, const char *key, double *data);
|
|
|
|
|
|
|
|
static __inline__ uint64_t rdtsc(void) {
|
|
|
|
unsigned hi, lo;
|
|
|
|
__asm__ __volatile__("rdtsc" : "=a"(lo), "=d"(hi));
|
|
|
|
return ((unsigned long long)lo) | (((unsigned long long)hi) << 32);
|
|
|
|
}
|
|
|
|
|
2022-07-22 11:34:29 +02:00
|
|
|
void update_slater_matrix(const uint64_t Lds, const uint64_t Dim,
|
2022-07-11 14:48:59 +02:00
|
|
|
const uint64_t N_updates, const double *Updates,
|
|
|
|
const uint64_t *Updates_index, double *Slater);
|
|
|
|
|
2022-07-22 11:34:29 +02:00
|
|
|
uint32_t check_error(const uint64_t Lds, const uint64_t Dim, double *Slater_invT,
|
2022-07-11 14:48:59 +02:00
|
|
|
double *Slater, const double tolerance);
|
|
|
|
|
|
|
|
int32_t check_error_better(const double max, const double tolerance);
|
|
|
|
|
2022-07-22 11:34:29 +02:00
|
|
|
uint32_t test_kernel(char *version, const uint64_t Lds, const uint64_t Dim,
|
2022-07-11 14:48:59 +02:00
|
|
|
const uint64_t N_updates, const double *Updates,
|
|
|
|
const uint64_t *Updates_index, const double breakdown, const double tolerance,
|
|
|
|
double *Slater, double *Slater_inv, double *determinant);
|