~ubuntu-branches/ubuntu/vivid/atlas/vivid

« back to all changes in this revision

Viewing changes to interfaces/lapack/C2F/src/ATL_C2Fgels.c

  • Committer: Package Import Robot
  • Author(s): Sébastien Villemot
  • Date: 2013-06-11 15:58:16 UTC
  • mfrom: (1.1.3 upstream)
  • mto: (2.2.21 experimental)
  • mto: This revision was merged to the branch mainline in revision 26.
  • Revision ID: package-import@ubuntu.com-20130611155816-b72z8f621tuhbzn0
Tags: upstream-3.10.1
Import upstream version 3.10.1

Show diffs side-by-side

added added

removed removed

Lines of Context:
 
1
/*
 
2
 *             Automatically Tuned Linear Algebra Software v3.10.1
 
3
 *                    (C) Copyright 2008 R. Clint Whaley
 
4
 *
 
5
 * Redistribution and use in source and binary forms, with or without
 
6
 * modification, are permitted provided that the following conditions
 
7
 * are met:
 
8
 *   1. Redistributions of source code must retain the above copyright
 
9
 *      notice, this list of conditions and the following disclaimer.
 
10
 *   2. Redistributions in binary form must reproduce the above copyright
 
11
 *      notice, this list of conditions, and the following disclaimer in the
 
12
 *      documentation and/or other materials provided with the distribution.
 
13
 *   3. The name of the ATLAS group or the names of its contributers may
 
14
 *      not be used to endorse or promote products derived from this
 
15
 *      software without specific written permission.
 
16
 *
 
17
 * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
 
18
 * ``AS IS'' AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED
 
19
 * TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR
 
20
 * PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE ATLAS GROUP OR ITS CONTRIBUTORS
 
21
 * BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
 
22
 * CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
 
23
 * SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
 
24
 * INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
 
25
 * CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
 
26
 * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
 
27
 * POSSIBILITY OF SUCH DAMAGE.
 
28
 *
 
29
 */
 
30
#include "atlas_misc.h"
 
31
#include "atlas_f77.h"
 
32
#include "atlas_C2Flapack.h"
 
33
 
 
34
#if defined(NoChange)
 
35
   #define F77GELS Mjoin(PRE,gels)
 
36
#elif defined (UpCase)
 
37
   #define F77GELS Mjoin(PREU,GELS)
 
38
#elif defined (Add_) || defined(Add__)
 
39
   #define F77GELS Mjoin(PRE,gels_)
 
40
#endif
 
41
#define PC2F Mjoin(ATL_C2F,PRE)
 
42
 
 
43
int Mjoin(PC2F,gels_wrk)(const enum CBLAS_TRANSPOSE TA, ATL_CINT M, ATL_CINT N,
 
44
                         ATL_CINT NRHS, TYPE *A, ATL_CINT lda,
 
45
                         TYPE *B, ATL_CINT ldb, TYPE *wrk, ATL_INT lwrk)
 
46
{
 
47
#if defined(StringSunStyle)
 
48
   F77_INTEGER ONE=1;
 
49
#elif defined(StringStructVal) || defined(StringStructPtr) || \
 
50
      defined(StringCrayStyle)
 
51
   F77_CHAR F77trans;
 
52
#endif
 
53
   F77_INTEGER F77M=M, F77N=N, F77NRHS=NRHS, F77lda=lda, F77ldb=ldb,
 
54
               F77lwrk = lwrk, F77info;
 
55
#if defined(StringSunStyle)
 
56
   void F77GELS(char*, F77_INTEGER*, F77_INTEGER*, F77_INTEGER*, TYPE*,
 
57
               F77_INTEGER*, TYPE*, F77_INTEGER*, TYPE*, F77_INTEGER*,
 
58
               F77_INTEGER*, F77_INTEGER);
 
59
#elif defined(StringStructPtr)
 
60
   void F77GELS(F77_CHAR*, F77_INTEGER*, F77_INTEGER*, F77_INTEGER*, TYPE*,
 
61
               F77_INTEGER*, TYPE*, F77_INTEGER*, TYPE*, F77_INTEGER*,
 
62
               F77_INTEGER*);
 
63
#else
 
64
   void F77GELS(F77_CHAR, F77_INTEGER*, F77_INTEGER*, F77_INTEGER*, TYPE*,
 
65
               F77_INTEGER*, TYPE*, F77_INTEGER*, TYPE*, F77_INTEGER*,
 
66
               F77_INTEGER*);
 
67
#endif
 
68
   char ctrans;
 
69
 
 
70
   if (TA == CblasNoTrans) ctrans = 'N';
 
71
   else if (TA == CblasTrans) ctrans = 'T';
 
72
   else ctrans = 'C';
 
73
#if defined(StringCrayStyle)
 
74
   f77trans = ATL_C2F_TransChar(cuplo);
 
75
#elif defined(StringStructVal) || defined(StringStructPtr)
 
76
   f77trans.len = 1;
 
77
   f77trans.cp = &ctrans;
 
78
#elif !defined(StringSunStyle)
 
79
   fprintf(stderr, "\n\nF77/C interface not defined!!\n\n");
 
80
   exit(-1);
 
81
#endif
 
82
 
 
83
#if defined(StringSunStyle)
 
84
   F77GELS(&ctrans, &F77M, &F77N, &F77NRHS, A, &F77lda, B, &F77ldb,
 
85
           wrk, &F77lwrk, &F77info, ONE);
 
86
#elif defined(StringStructPtr)
 
87
   F77GELS(&f77trans, &F77M, &F77N, &F77NRHS, A, &F77lda, B, &F77ldb,
 
88
           wrk, &F77lwrk, &F77info);
 
89
#elif defined(StringStructVal) || defined(StringCrayStyle)
 
90
   F77GELS(f77trans, &F77M, &F77N, &F77NRHS, A, &F77lda, B, &F77ldb,
 
91
           wrk, &F77lwrk, &F77info);
 
92
#endif
 
93
   return(F77info);
 
94
}
 
95
 
 
96
int Mjoin(PC2F,gels)(const enum CBLAS_TRANSPOSE TA, ATL_CINT M, ATL_CINT N,
 
97
                     ATL_CINT NRHS, TYPE *A, ATL_CINT lda,
 
98
                     TYPE *B, ATL_CINT ldb)
 
99
{
 
100
   TYPE work[2];
 
101
   TYPE *wrk;
 
102
   ATL_INT lwrk;
 
103
   int iret;
 
104
/*
 
105
 * Query routine for optimal workspace, allocate it, and call routine with it
 
106
 */
 
107
   ATL_assert(!Mjoin(PC2F,gels_wrk)(TA, M, N, NRHS, A, lda, B, ldb, work, -1));
 
108
   lwrk = work[0];
 
109
   wrk = malloc(ATL_MulBySize(lwrk));
 
110
   ATL_assert(wrk);
 
111
   iret = Mjoin(PC2F,gels_wrk)(TA, M, N, NRHS, A, lda, B, ldb, wrk, lwrk);
 
112
   free(wrk);
 
113
   return(iret);
 
114
}