2023-08-02 16:17:43 +02:00
|
|
|
#include <stdio.h>
|
|
|
|
#include <stdlib.h>
|
|
|
|
#include <string.h>
|
|
|
|
#include <omp.h>
|
|
|
|
#include <cublas_v2.h>
|
|
|
|
#include <cuda_runtime.h>
|
|
|
|
#include "gpu.h"
|
2023-08-21 12:34:55 +02:00
|
|
|
#include "assert.h"
|
2023-08-02 16:17:43 +02:00
|
|
|
|
|
|
|
gpu_data* gpu_init(
|
|
|
|
int nO, int nV, int cholesky_mo_num,
|
|
|
|
double* cc_space_v_oo_chol, double* cc_space_v_ov_chol,
|
|
|
|
double* cc_space_v_vo_chol, double* cc_space_v_vv_chol,
|
2023-08-04 15:49:48 +02:00
|
|
|
double* cc_space_v_oooo, double* cc_space_v_vooo, double* cc_space_v_voov,
|
2023-08-02 16:17:43 +02:00
|
|
|
double* cc_space_v_oovv, double* cc_space_v_vvoo,
|
|
|
|
double* cc_space_v_oovo, double* cc_space_v_ovvo,
|
2023-08-03 01:21:16 +02:00
|
|
|
double* cc_space_v_ovov, double* cc_space_v_ovoo,
|
2023-08-04 14:07:49 +02:00
|
|
|
double* cc_space_f_oo, double* cc_space_f_ov,
|
|
|
|
double* cc_space_f_vo, double* cc_space_f_vv)
|
2023-08-02 16:17:43 +02:00
|
|
|
{
|
|
|
|
int ngpus = 1;
|
2023-08-21 12:34:55 +02:00
|
|
|
if (MULTIGPU == 1) cudaGetDeviceCount(&ngpus);
|
2023-08-02 16:17:43 +02:00
|
|
|
|
|
|
|
gpu_data* data = (gpu_data*) malloc (ngpus*sizeof(gpu_data));
|
2023-08-21 12:34:55 +02:00
|
|
|
assert (data != NULL);
|
2023-08-02 16:17:43 +02:00
|
|
|
|
|
|
|
#pragma omp parallel num_threads(ngpus)
|
|
|
|
{
|
2023-08-21 12:34:55 +02:00
|
|
|
cudaError_t cudaStat = cudaSuccess;
|
|
|
|
size_t lda;
|
|
|
|
|
2023-08-02 16:17:43 +02:00
|
|
|
int igpu = omp_get_thread_num();
|
|
|
|
cudaSetDevice(igpu);
|
|
|
|
cublasHandle_t handle;
|
|
|
|
cublasCreate(&handle);
|
|
|
|
|
|
|
|
double* d_cc_space_v_oo_chol;
|
|
|
|
lda = cholesky_mo_num * nO;
|
2023-08-21 12:34:55 +02:00
|
|
|
cudaStat = cudaMalloc((void **)&d_cc_space_v_oo_chol, lda * nO * sizeof(double));
|
|
|
|
assert (cudaStat == cudaSuccess);
|
2023-08-02 16:17:43 +02:00
|
|
|
cublasSetMatrix(cholesky_mo_num*nO, nO, sizeof(double), cc_space_v_oo_chol, lda, d_cc_space_v_oo_chol, lda);
|
|
|
|
|
|
|
|
double* d_cc_space_v_ov_chol;
|
|
|
|
lda = cholesky_mo_num * nO;
|
2023-08-21 12:34:55 +02:00
|
|
|
cudaStat = cudaMalloc((void **)&d_cc_space_v_ov_chol, lda * nV * sizeof(double));
|
|
|
|
assert (cudaStat == cudaSuccess);
|
2023-08-02 16:17:43 +02:00
|
|
|
cublasSetMatrix(cholesky_mo_num*nO, nV, sizeof(double), cc_space_v_ov_chol, lda, d_cc_space_v_ov_chol, lda);
|
|
|
|
|
|
|
|
double* d_cc_space_v_vo_chol;
|
|
|
|
lda = cholesky_mo_num * nV;
|
2023-08-21 12:34:55 +02:00
|
|
|
cudaStat = cudaMalloc((void **)&d_cc_space_v_vo_chol, lda * nO * sizeof(double));
|
|
|
|
assert (cudaStat == cudaSuccess);
|
2023-08-02 16:17:43 +02:00
|
|
|
cublasSetMatrix(cholesky_mo_num*nV, nO, sizeof(double), cc_space_v_vo_chol, lda, d_cc_space_v_vo_chol, lda);
|
|
|
|
|
|
|
|
double* d_cc_space_v_vv_chol;
|
|
|
|
lda = cholesky_mo_num * nV;
|
2023-08-21 12:34:55 +02:00
|
|
|
cudaStat = cudaMalloc((void **)&d_cc_space_v_vv_chol, lda * nV * sizeof(double));
|
|
|
|
assert (cudaStat == cudaSuccess);
|
2023-08-02 16:17:43 +02:00
|
|
|
cublasSetMatrix(cholesky_mo_num*nV, nV, sizeof(double), cc_space_v_vv_chol, lda, d_cc_space_v_vv_chol, lda);
|
|
|
|
|
|
|
|
double* d_cc_space_v_oooo;
|
2023-08-21 12:34:55 +02:00
|
|
|
cudaStat = cudaMalloc((void**)&d_cc_space_v_oooo, nO*nO*nO*nO*sizeof(double));
|
|
|
|
assert (cudaStat == cudaSuccess);
|
2023-08-02 16:17:43 +02:00
|
|
|
cublasSetMatrix(nO*nO, nO*nO, sizeof(double), cc_space_v_oooo, nO*nO, d_cc_space_v_oooo, nO*nO);
|
|
|
|
|
|
|
|
double* d_cc_space_v_vooo;
|
2023-08-21 12:34:55 +02:00
|
|
|
cudaStat = cudaMalloc((void**)&d_cc_space_v_vooo, nV*nO*nO*nO*sizeof(double));
|
|
|
|
assert (cudaStat == cudaSuccess);
|
2023-08-02 16:17:43 +02:00
|
|
|
cublasSetMatrix(nV*nO, nO*nO, sizeof(double), cc_space_v_vooo, nV*nO, d_cc_space_v_vooo, nV*nO);
|
|
|
|
|
2023-08-04 15:49:48 +02:00
|
|
|
double* d_cc_space_v_voov;
|
2023-08-21 12:34:55 +02:00
|
|
|
cudaStat = cudaMalloc((void**)&d_cc_space_v_voov, nV*nO*nO*nV*sizeof(double));
|
|
|
|
assert (cudaStat == cudaSuccess);
|
2023-08-04 15:49:48 +02:00
|
|
|
cublasSetMatrix(nV*nO, nO*nV, sizeof(double), cc_space_v_voov, nV*nO, d_cc_space_v_voov, nV*nO);
|
|
|
|
|
2023-08-02 16:17:43 +02:00
|
|
|
double* d_cc_space_v_oovv;
|
2023-08-21 12:34:55 +02:00
|
|
|
cudaStat = cudaMalloc((void**)&d_cc_space_v_oovv, nO*nO*nV*nV*sizeof(double));
|
|
|
|
assert (cudaStat == cudaSuccess);
|
2023-08-02 16:17:43 +02:00
|
|
|
cublasSetMatrix(nO*nO, nV*nV, sizeof(double), cc_space_v_oovv, nO*nO, d_cc_space_v_oovv, nO*nO);
|
|
|
|
|
|
|
|
double* d_cc_space_v_vvoo;
|
2023-08-21 12:34:55 +02:00
|
|
|
cudaStat = cudaMalloc((void**)&d_cc_space_v_vvoo, nV*nV*nO*nO*sizeof(double));
|
|
|
|
assert (cudaStat == cudaSuccess);
|
2023-08-02 16:17:43 +02:00
|
|
|
cublasSetMatrix(nV*nV, nO*nO, sizeof(double), cc_space_v_vvoo, nV*nV, d_cc_space_v_vvoo, nV*nV);
|
|
|
|
|
|
|
|
double* d_cc_space_v_oovo;
|
|
|
|
lda = nO*nO;
|
2023-08-21 12:34:55 +02:00
|
|
|
cudaStat = cudaMalloc((void **)&d_cc_space_v_oovo, nO*nO*nV*nO * sizeof(double));
|
|
|
|
assert (cudaStat == cudaSuccess);
|
2023-08-02 16:17:43 +02:00
|
|
|
cublasSetMatrix(lda, nV*nO, sizeof(double), cc_space_v_oovo, lda, d_cc_space_v_oovo, lda);
|
|
|
|
|
|
|
|
double* d_cc_space_v_ovvo;
|
|
|
|
lda = nO*nV;
|
2023-08-21 12:34:55 +02:00
|
|
|
cudaStat = cudaMalloc((void **)&d_cc_space_v_ovvo, nO*nV*nV*nO * sizeof(double));
|
|
|
|
assert (cudaStat == cudaSuccess);
|
2023-08-02 16:17:43 +02:00
|
|
|
cublasSetMatrix(lda, nV*nO, sizeof(double), cc_space_v_ovvo, lda, d_cc_space_v_ovvo, lda);
|
|
|
|
|
2023-08-03 01:21:16 +02:00
|
|
|
double* d_cc_space_v_ovov;
|
|
|
|
lda = nO*nV;
|
2023-08-21 12:34:55 +02:00
|
|
|
cudaStat = cudaMalloc((void **)&d_cc_space_v_ovov, nO*nV*nV*nO * sizeof(double));
|
|
|
|
assert (cudaStat == cudaSuccess);
|
2023-08-03 01:21:16 +02:00
|
|
|
cublasSetMatrix(lda, nV*nO, sizeof(double), cc_space_v_ovov, lda, d_cc_space_v_ovov, lda);
|
|
|
|
|
2023-08-02 16:17:43 +02:00
|
|
|
double* d_cc_space_v_ovoo;
|
|
|
|
lda = nO*nV;
|
2023-08-21 12:34:55 +02:00
|
|
|
cudaStat = cudaMalloc((void **)&d_cc_space_v_ovoo, nO*nV*nO*nO * sizeof(double));
|
|
|
|
assert (cudaStat == cudaSuccess);
|
2023-08-02 16:17:43 +02:00
|
|
|
cublasSetMatrix(lda, nO*nO, sizeof(double), cc_space_v_ovoo, lda, d_cc_space_v_ovoo, lda);
|
|
|
|
|
2023-08-03 19:46:41 +02:00
|
|
|
double* d_cc_space_f_oo;
|
2023-08-21 12:34:55 +02:00
|
|
|
cudaStat = cudaMalloc((void**)&d_cc_space_f_oo, nO*nO*sizeof(double));
|
|
|
|
assert (cudaStat == cudaSuccess);
|
2023-08-03 19:46:41 +02:00
|
|
|
cublasSetMatrix(nO, nO, sizeof(double), cc_space_f_oo, nO, d_cc_space_f_oo, nO);
|
|
|
|
|
2023-08-02 16:17:43 +02:00
|
|
|
double* d_cc_space_f_vo;
|
2023-08-21 12:34:55 +02:00
|
|
|
cudaStat = cudaMalloc((void**)&d_cc_space_f_vo, nV*nO*sizeof(double));
|
|
|
|
assert (cudaStat == cudaSuccess);
|
2023-08-02 16:17:43 +02:00
|
|
|
cublasSetMatrix(nV, nO, sizeof(double), cc_space_f_vo, nV, d_cc_space_f_vo, nV);
|
|
|
|
|
2023-08-04 14:07:49 +02:00
|
|
|
double* d_cc_space_f_ov;
|
2023-08-21 12:34:55 +02:00
|
|
|
cudaStat = cudaMalloc((void**)&d_cc_space_f_ov, nV*nO*sizeof(double));
|
|
|
|
assert (cudaStat == cudaSuccess);
|
2023-08-04 14:07:49 +02:00
|
|
|
cublasSetMatrix(nO, nV, sizeof(double), cc_space_f_ov, nO, d_cc_space_f_ov, nO);
|
|
|
|
|
2023-08-03 19:46:41 +02:00
|
|
|
double* d_cc_space_f_vv;
|
2023-08-21 12:34:55 +02:00
|
|
|
cudaStat = cudaMalloc((void**)&d_cc_space_f_vv, nV*nV*sizeof(double));
|
|
|
|
assert (cudaStat == cudaSuccess);
|
2023-08-03 19:46:41 +02:00
|
|
|
cublasSetMatrix(nV, nV, sizeof(double), cc_space_f_vv, nV, d_cc_space_f_vv, nV);
|
|
|
|
|
2023-08-03 17:29:57 +02:00
|
|
|
double* d_tau;
|
|
|
|
lda = nO * nO;
|
2023-08-21 12:34:55 +02:00
|
|
|
cudaStat = cudaMalloc((void **)&d_tau, lda * nV * nV * sizeof(double));
|
|
|
|
assert (cudaStat == cudaSuccess);
|
2023-08-03 17:29:57 +02:00
|
|
|
|
|
|
|
double* d_tau_x;
|
|
|
|
lda = nO * nO;
|
2023-08-21 12:34:55 +02:00
|
|
|
cudaStat = cudaMalloc((void **)&d_tau_x, lda * nV * nV * sizeof(double));
|
|
|
|
assert (cudaStat == cudaSuccess);
|
2023-08-03 17:29:57 +02:00
|
|
|
|
|
|
|
double* d_t1;
|
2023-08-21 12:34:55 +02:00
|
|
|
cudaStat = cudaMalloc((void **)&d_t1, nO * nV * sizeof(double));
|
|
|
|
assert (cudaStat == cudaSuccess);
|
2023-08-03 17:29:57 +02:00
|
|
|
|
|
|
|
double* d_t2;
|
2023-08-21 12:34:55 +02:00
|
|
|
cudaStat = cudaMalloc((void **)&d_t2, nO*nO*nV*nV * sizeof(double));
|
|
|
|
assert (cudaStat == cudaSuccess);
|
2023-08-03 17:29:57 +02:00
|
|
|
|
|
|
|
double* d_H_oo;
|
2023-08-21 12:34:55 +02:00
|
|
|
cudaStat = cudaMalloc((void **)&d_H_oo, nO * nO * sizeof(double));
|
|
|
|
assert (cudaStat == cudaSuccess);
|
2023-08-03 17:29:57 +02:00
|
|
|
|
2023-08-04 12:33:52 +02:00
|
|
|
double* d_H_vo;
|
2023-08-21 12:34:55 +02:00
|
|
|
cudaStat = cudaMalloc((void **)&d_H_vo, nV * nO * sizeof(double));
|
|
|
|
assert (cudaStat == cudaSuccess);
|
2023-08-04 12:33:52 +02:00
|
|
|
|
2023-08-03 17:29:57 +02:00
|
|
|
double* d_H_vv;
|
2023-08-21 12:34:55 +02:00
|
|
|
cudaStat = cudaMalloc((void **)&d_H_vv, nV * nV * sizeof(double));
|
|
|
|
assert (cudaStat == cudaSuccess);
|
2023-08-03 17:29:57 +02:00
|
|
|
|
2023-08-02 16:17:43 +02:00
|
|
|
data[igpu].cc_space_v_oo_chol = d_cc_space_v_oo_chol;
|
|
|
|
data[igpu].cc_space_v_ov_chol = d_cc_space_v_ov_chol;
|
|
|
|
data[igpu].cc_space_v_vo_chol = d_cc_space_v_vo_chol;
|
|
|
|
data[igpu].cc_space_v_vv_chol = d_cc_space_v_vv_chol;
|
|
|
|
data[igpu].cc_space_v_oooo = d_cc_space_v_oooo;
|
|
|
|
data[igpu].cc_space_v_vooo = d_cc_space_v_vooo;
|
2023-08-04 15:49:48 +02:00
|
|
|
data[igpu].cc_space_v_voov = d_cc_space_v_voov;
|
2023-08-02 16:17:43 +02:00
|
|
|
data[igpu].cc_space_v_oovv = d_cc_space_v_oovv;
|
|
|
|
data[igpu].cc_space_v_vvoo = d_cc_space_v_vvoo;
|
|
|
|
data[igpu].cc_space_v_oovo = d_cc_space_v_oovo;
|
|
|
|
data[igpu].cc_space_v_ovvo = d_cc_space_v_ovvo;
|
2023-08-03 01:21:16 +02:00
|
|
|
data[igpu].cc_space_v_ovov = d_cc_space_v_ovov;
|
2023-08-02 16:17:43 +02:00
|
|
|
data[igpu].cc_space_v_ovoo = d_cc_space_v_ovoo;
|
2023-08-03 19:46:41 +02:00
|
|
|
data[igpu].cc_space_f_oo = d_cc_space_f_oo;
|
2023-08-04 14:07:49 +02:00
|
|
|
data[igpu].cc_space_f_ov = d_cc_space_f_ov;
|
2023-08-03 19:46:41 +02:00
|
|
|
data[igpu].cc_space_f_vo = d_cc_space_f_vo;
|
|
|
|
data[igpu].cc_space_f_vv = d_cc_space_f_vv;
|
2023-08-03 17:29:57 +02:00
|
|
|
data[igpu].tau = d_tau;
|
|
|
|
data[igpu].tau_x = d_tau_x;
|
|
|
|
data[igpu].t1 = d_t1;
|
|
|
|
data[igpu].t2 = d_t2;
|
|
|
|
data[igpu].H_oo = d_H_oo;
|
2023-08-04 12:33:52 +02:00
|
|
|
data[igpu].H_vo = d_H_vo;
|
2023-08-03 17:29:57 +02:00
|
|
|
data[igpu].H_vv = d_H_vv;
|
|
|
|
|
|
|
|
data[igpu].nO = nO;
|
|
|
|
data[igpu].nV = nV;
|
|
|
|
data[igpu].cholesky_mo_num = cholesky_mo_num;
|
|
|
|
|
2023-08-02 16:17:43 +02:00
|
|
|
}
|
|
|
|
return data;
|
|
|
|
}
|
|
|
|
|
|
|
|
|
2023-08-21 12:34:55 +02:00
|
|
|
void gpu_deinit(gpu_data* data)
|
|
|
|
{
|
|
|
|
int ngpus = 1;
|
|
|
|
if (MULTIGPU == 1) cudaGetDeviceCount(&ngpus);
|
|
|
|
|
|
|
|
#pragma omp parallel num_threads(ngpus)
|
|
|
|
{
|
|
|
|
size_t lda;
|
|
|
|
int igpu = omp_get_thread_num();
|
|
|
|
cudaSetDevice(igpu);
|
|
|
|
|
|
|
|
free(data[igpu].cc_space_v_oo_chol);
|
|
|
|
free(data[igpu].cc_space_v_ov_chol);
|
|
|
|
free(data[igpu].cc_space_v_vo_chol);
|
|
|
|
free(data[igpu].cc_space_v_vv_chol);
|
|
|
|
free(data[igpu].cc_space_v_oooo);
|
|
|
|
free(data[igpu].cc_space_v_vooo);
|
|
|
|
free(data[igpu].cc_space_v_voov);
|
|
|
|
free(data[igpu].cc_space_v_oovv);
|
|
|
|
free(data[igpu].cc_space_v_vvoo);
|
|
|
|
free(data[igpu].cc_space_v_oovo);
|
|
|
|
free(data[igpu].cc_space_v_ovvo);
|
|
|
|
free(data[igpu].cc_space_v_ovov);
|
|
|
|
free(data[igpu].cc_space_v_ovoo);
|
|
|
|
free(data[igpu].cc_space_f_oo);
|
|
|
|
free(data[igpu].cc_space_f_ov);
|
|
|
|
free(data[igpu].cc_space_f_vo);
|
|
|
|
free(data[igpu].cc_space_f_vv);
|
|
|
|
free(data[igpu].tau);
|
|
|
|
free(data[igpu].tau_x);
|
|
|
|
free(data[igpu].t1);
|
|
|
|
free(data[igpu].t2);
|
|
|
|
free(data[igpu].H_oo);
|
|
|
|
free(data[igpu].H_vo);
|
|
|
|
free(data[igpu].H_vv);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|