Home | History | Annotate | Download | only in src
      1 /*
      2  * cblas_cher.c
      3  * The program is a C interface to cher.
      4  *
      5  * Keita Teranishi  5/20/98
      6  *
      7  */
      8 #include <stdio.h>
      9 #include <stdlib.h>
     10 #include "cblas.h"
     11 #include "cblas_f77.h"
     12 void cblas_cher(const enum CBLAS_ORDER order, const enum CBLAS_UPLO Uplo,
     13                 const int N, const float alpha, const void *X, const int incX
     14                 ,void *A, const int lda)
     15 {
     16    char UL;
     17 #ifdef F77_CHAR
     18    F77_CHAR F77_UL;
     19 #else
     20    #define F77_UL &UL
     21 #endif
     22 
     23 #ifdef F77_INT
     24    F77_INT F77_N=N, F77_lda=lda, F77_incX=incX;
     25 #else
     26    #define F77_N N
     27    #define F77_lda lda
     28    #define F77_incX incx
     29 #endif
     30    int n, i, tincx, incx=incX;
     31    float *x=(float *)X, *xx=(float *)X, *tx, *st;
     32 
     33    extern int CBLAS_CallFromC;
     34    extern int RowMajorStrg;
     35    RowMajorStrg = 0;
     36 
     37    CBLAS_CallFromC = 1;
     38    if (order == CblasColMajor)
     39    {
     40       if (Uplo == CblasLower) UL = 'L';
     41       else if (Uplo == CblasUpper) UL = 'U';
     42       else
     43       {
     44          cblas_xerbla(2, "cblas_cher","Illegal Uplo setting, %d\n",Uplo );
     45          CBLAS_CallFromC = 0;
     46          RowMajorStrg = 0;
     47          return;
     48       }
     49       #ifdef F77_CHAR
     50          F77_UL = C2F_CHAR(&UL);
     51       #endif
     52 
     53       F77_cher(F77_UL, &F77_N, &alpha, X, &F77_incX, A, &F77_lda);
     54 
     55    }  else if (order == CblasRowMajor)
     56    {
     57       RowMajorStrg = 1;
     58       if (Uplo == CblasUpper) UL = 'L';
     59       else if (Uplo == CblasLower) UL = 'U';
     60       else
     61       {
     62          cblas_xerbla(2, "cblas_cher","Illegal Uplo setting, %d\n", Uplo);
     63          CBLAS_CallFromC = 0;
     64          RowMajorStrg = 0;
     65          return;
     66       }
     67       #ifdef F77_CHAR
     68          F77_UL = C2F_CHAR(&UL);
     69       #endif
     70       if (N > 0)
     71       {
     72          n = N << 1;
     73          x = malloc(n*sizeof(float));
     74          tx = x;
     75          if( incX > 0 ) {
     76             i = incX << 1 ;
     77             tincx = 2;
     78             st= x+n;
     79          } else {
     80             i = incX *(-2);
     81             tincx = -2;
     82             st = x-2;
     83             x +=(n-2);
     84          }
     85          do
     86          {
     87             *x = *xx;
     88             x[1] = -xx[1];
     89             x += tincx ;
     90             xx += i;
     91          }
     92          while (x != st);
     93          x=tx;
     94 
     95          #ifdef F77_INT
     96            F77_incX = 1;
     97          #else
     98            incx = 1;
     99          #endif
    100       }
    101       else x = (float *) X;
    102       F77_cher(F77_UL, &F77_N, &alpha, x, &F77_incX, A, &F77_lda);
    103    } else
    104    {
    105       cblas_xerbla(1, "cblas_cher","Illegal Order setting, %d\n", order);
    106       CBLAS_CallFromC = 0;
    107       RowMajorStrg = 0;
    108       return;
    109    }
    110    if(X!=x)
    111       free(x);
    112 
    113    CBLAS_CallFromC = 0;
    114    RowMajorStrg = 0;
    115    return;
    116 }
    117