AnalysisSystemForRadionucli.../include/armadillo_bits/def_blas.hpp
2024-06-04 15:25:02 +08:00

103 lines
4.9 KiB
C++

// Copyright (C) 2008-2015 National ICT Australia (NICTA)
//
// This Source Code Form is subject to the terms of the Mozilla Public
// License, v. 2.0. If a copy of the MPL was not distributed with this
// file, You can obtain one at http://mozilla.org/MPL/2.0/.
// -------------------------------------------------------------------
//
// Written by Conrad Sanderson - http://conradsanderson.id.au
#ifdef ARMA_USE_BLAS
#if !defined(ARMA_BLAS_CAPITALS)
#define arma_sasum sasum
#define arma_dasum dasum
#define arma_snrm2 snrm2
#define arma_dnrm2 dnrm2
#define arma_sdot sdot
#define arma_ddot ddot
#define arma_sgemv sgemv
#define arma_dgemv dgemv
#define arma_cgemv cgemv
#define arma_zgemv zgemv
#define arma_sgemm sgemm
#define arma_dgemm dgemm
#define arma_cgemm cgemm
#define arma_zgemm zgemm
#define arma_ssyrk ssyrk
#define arma_dsyrk dsyrk
#define arma_cherk cherk
#define arma_zherk zherk
#else
#define arma_sasum SASUM
#define arma_dasum DASUM
#define arma_snrm2 SNRM2
#define arma_dnrm2 DNRM2
#define arma_sdot SDOT
#define arma_ddot DDOT
#define arma_sgemv SGEMV
#define arma_dgemv DGEMV
#define arma_cgemv CGEMV
#define arma_zgemv ZGEMV
#define arma_sgemm SGEMM
#define arma_dgemm DGEMM
#define arma_cgemm CGEMM
#define arma_zgemm ZGEMM
#define arma_ssyrk SSYRK
#define arma_dsyrk DSYRK
#define arma_cherk CHERK
#define arma_zherk ZHERK
#endif
extern "C"
{
float arma_fortran(arma_sasum)(blas_int* n, const float* x, blas_int* incx);
double arma_fortran(arma_dasum)(blas_int* n, const double* x, blas_int* incx);
float arma_fortran(arma_snrm2)(blas_int* n, const float* x, blas_int* incx);
double arma_fortran(arma_dnrm2)(blas_int* n, const double* x, blas_int* incx);
float arma_fortran(arma_sdot)(blas_int* n, const float* x, blas_int* incx, const float* y, blas_int* incy);
double arma_fortran(arma_ddot)(blas_int* n, const double* x, blas_int* incx, const double* y, blas_int* incy);
void arma_fortran(arma_sgemv)(const char* transA, const blas_int* m, const blas_int* n, const float* alpha, const float* A, const blas_int* ldA, const float* x, const blas_int* incx, const float* beta, float* y, const blas_int* incy);
void arma_fortran(arma_dgemv)(const char* transA, const blas_int* m, const blas_int* n, const double* alpha, const double* A, const blas_int* ldA, const double* x, const blas_int* incx, const double* beta, double* y, const blas_int* incy);
void arma_fortran(arma_cgemv)(const char* transA, const blas_int* m, const blas_int* n, const void* alpha, const void* A, const blas_int* ldA, const void* x, const blas_int* incx, const void* beta, void* y, const blas_int* incy);
void arma_fortran(arma_zgemv)(const char* transA, const blas_int* m, const blas_int* n, const void* alpha, const void* A, const blas_int* ldA, const void* x, const blas_int* incx, const void* beta, void* y, const blas_int* incy);
void arma_fortran(arma_sgemm)(const char* transA, const char* transB, const blas_int* m, const blas_int* n, const blas_int* k, const float* alpha, const float* A, const blas_int* ldA, const float* B, const blas_int* ldB, const float* beta, float* C, const blas_int* ldC);
void arma_fortran(arma_dgemm)(const char* transA, const char* transB, const blas_int* m, const blas_int* n, const blas_int* k, const double* alpha, const double* A, const blas_int* ldA, const double* B, const blas_int* ldB, const double* beta, double* C, const blas_int* ldC);
void arma_fortran(arma_cgemm)(const char* transA, const char* transB, const blas_int* m, const blas_int* n, const blas_int* k, const void* alpha, const void* A, const blas_int* ldA, const void* B, const blas_int* ldB, const void* beta, void* C, const blas_int* ldC);
void arma_fortran(arma_zgemm)(const char* transA, const char* transB, const blas_int* m, const blas_int* n, const blas_int* k, const void* alpha, const void* A, const blas_int* ldA, const void* B, const blas_int* ldB, const void* beta, void* C, const blas_int* ldC);
void arma_fortran(arma_ssyrk)(const char* uplo, const char* transA, const blas_int* n, const blas_int* k, const float* alpha, const float* A, const blas_int* ldA, const float* beta, float* C, const blas_int* ldC);
void arma_fortran(arma_dsyrk)(const char* uplo, const char* transA, const blas_int* n, const blas_int* k, const double* alpha, const double* A, const blas_int* ldA, const double* beta, double* C, const blas_int* ldC);
void arma_fortran(arma_cherk)(const char* uplo, const char* transA, const blas_int* n, const blas_int* k, const float* alpha, const void* A, const blas_int* ldA, const float* beta, void* C, const blas_int* ldC);
void arma_fortran(arma_zherk)(const char* uplo, const char* transA, const blas_int* n, const blas_int* k, const double* alpha, const void* A, const blas_int* ldA, const double* beta, void* C, const blas_int* ldC);
}
#endif