00001
00002
00003
00004
00005
00006
00007
00008
00009
00010
00011
00012
00013 #include "f2c.h"
00014 #include "blaswrap.h"
00015
00016
00017
00018 static integer c__1 = 1;
00019 static integer c_n1 = -1;
00020 static integer c__2 = 2;
00021 static integer c__65 = 65;
00022
00023 int sormrz_(char *side, char *trans, integer *m, integer *n,
00024 integer *k, integer *l, real *a, integer *lda, real *tau, real *c__,
00025 integer *ldc, real *work, integer *lwork, integer *info)
00026 {
00027
00028 address a__1[2];
00029 integer a_dim1, a_offset, c_dim1, c_offset, i__1, i__2, i__3[2], i__4,
00030 i__5;
00031 char ch__1[2];
00032
00033
00034 int s_cat(char *, char **, integer *, integer *, ftnlen);
00035
00036
00037 integer i__;
00038 real t[4160] ;
00039 integer i1, i2, i3, ib, ic, ja, jc, nb, mi, ni, nq, nw, iws;
00040 logical left;
00041 extern logical lsame_(char *, char *);
00042 integer nbmin, iinfo;
00043 extern int sormr3_(char *, char *, integer *, integer *,
00044 integer *, integer *, real *, integer *, real *, real *, integer *
00045 , real *, integer *), xerbla_(char *, integer *);
00046 extern integer ilaenv_(integer *, char *, char *, integer *, integer *,
00047 integer *, integer *);
00048 extern int slarzb_(char *, char *, char *, char *,
00049 integer *, integer *, integer *, integer *, real *, integer *,
00050 real *, integer *, real *, integer *, real *, integer *);
00051 logical notran;
00052 integer ldwork;
00053 char transt[1];
00054 extern int slarzt_(char *, char *, integer *, integer *,
00055 real *, integer *, real *, real *, integer *);
00056 integer lwkopt;
00057 logical lquery;
00058
00059
00060
00061
00062
00063
00064
00065
00066
00067
00068
00069
00070
00071
00072
00073
00074
00075
00076
00077
00078
00079
00080
00081
00082
00083
00084
00085
00086
00087
00088
00089
00090
00091
00092
00093
00094
00095
00096
00097
00098
00099
00100
00101
00102
00103
00104
00105
00106
00107
00108
00109
00110
00111
00112
00113
00114
00115
00116
00117
00118
00119
00120
00121
00122
00123
00124
00125
00126
00127
00128
00129
00130
00131
00132
00133
00134
00135
00136
00137
00138
00139
00140
00141
00142
00143
00144
00145
00146
00147
00148
00149
00150
00151
00152
00153
00154
00155
00156
00157
00158
00159
00160
00161
00162
00163
00164
00165
00166
00167
00168
00169
00170
00171
00172
00173
00174
00175
00176
00177
00178
00179
00180
00181 a_dim1 = *lda;
00182 a_offset = 1 + a_dim1;
00183 a -= a_offset;
00184 --tau;
00185 c_dim1 = *ldc;
00186 c_offset = 1 + c_dim1;
00187 c__ -= c_offset;
00188 --work;
00189
00190
00191 *info = 0;
00192 left = lsame_(side, "L");
00193 notran = lsame_(trans, "N");
00194 lquery = *lwork == -1;
00195
00196
00197
00198 if (left) {
00199 nq = *m;
00200 nw = max(1,*n);
00201 } else {
00202 nq = *n;
00203 nw = max(1,*m);
00204 }
00205 if (! left && ! lsame_(side, "R")) {
00206 *info = -1;
00207 } else if (! notran && ! lsame_(trans, "T")) {
00208 *info = -2;
00209 } else if (*m < 0) {
00210 *info = -3;
00211 } else if (*n < 0) {
00212 *info = -4;
00213 } else if (*k < 0 || *k > nq) {
00214 *info = -5;
00215 } else if (*l < 0 || left && *l > *m || ! left && *l > *n) {
00216 *info = -6;
00217 } else if (*lda < max(1,*k)) {
00218 *info = -8;
00219 } else if (*ldc < max(1,*m)) {
00220 *info = -11;
00221 }
00222
00223 if (*info == 0) {
00224 if (*m == 0 || *n == 0) {
00225 lwkopt = 1;
00226 } else {
00227
00228
00229
00230
00231
00232
00233 i__3[0] = 1, a__1[0] = side;
00234 i__3[1] = 1, a__1[1] = trans;
00235 s_cat(ch__1, a__1, i__3, &c__2, (ftnlen)2);
00236 i__1 = 64, i__2 = ilaenv_(&c__1, "SORMRQ", ch__1, m, n, k, &c_n1);
00237 nb = min(i__1,i__2);
00238 lwkopt = nw * nb;
00239 }
00240 work[1] = (real) lwkopt;
00241
00242 if (*lwork < max(1,nw) && ! lquery) {
00243 *info = -13;
00244 }
00245 }
00246
00247 if (*info != 0) {
00248 i__1 = -(*info);
00249 xerbla_("SORMRZ", &i__1);
00250 return 0;
00251 } else if (lquery) {
00252 return 0;
00253 }
00254
00255
00256
00257 if (*m == 0 || *n == 0) {
00258 return 0;
00259 }
00260
00261 nbmin = 2;
00262 ldwork = nw;
00263 if (nb > 1 && nb < *k) {
00264 iws = nw * nb;
00265 if (*lwork < iws) {
00266 nb = *lwork / ldwork;
00267
00268
00269 i__3[0] = 1, a__1[0] = side;
00270 i__3[1] = 1, a__1[1] = trans;
00271 s_cat(ch__1, a__1, i__3, &c__2, (ftnlen)2);
00272 i__1 = 2, i__2 = ilaenv_(&c__2, "SORMRQ", ch__1, m, n, k, &c_n1);
00273 nbmin = max(i__1,i__2);
00274 }
00275 } else {
00276 iws = nw;
00277 }
00278
00279 if (nb < nbmin || nb >= *k) {
00280
00281
00282
00283 sormr3_(side, trans, m, n, k, l, &a[a_offset], lda, &tau[1], &c__[
00284 c_offset], ldc, &work[1], &iinfo);
00285 } else {
00286
00287
00288
00289 if (left && ! notran || ! left && notran) {
00290 i1 = 1;
00291 i2 = *k;
00292 i3 = nb;
00293 } else {
00294 i1 = (*k - 1) / nb * nb + 1;
00295 i2 = 1;
00296 i3 = -nb;
00297 }
00298
00299 if (left) {
00300 ni = *n;
00301 jc = 1;
00302 ja = *m - *l + 1;
00303 } else {
00304 mi = *m;
00305 ic = 1;
00306 ja = *n - *l + 1;
00307 }
00308
00309 if (notran) {
00310 *(unsigned char *)transt = 'T';
00311 } else {
00312 *(unsigned char *)transt = 'N';
00313 }
00314
00315 i__1 = i2;
00316 i__2 = i3;
00317 for (i__ = i1; i__2 < 0 ? i__ >= i__1 : i__ <= i__1; i__ += i__2) {
00318
00319 i__4 = nb, i__5 = *k - i__ + 1;
00320 ib = min(i__4,i__5);
00321
00322
00323
00324
00325 slarzt_("Backward", "Rowwise", l, &ib, &a[i__ + ja * a_dim1], lda,
00326 &tau[i__], t, &c__65);
00327
00328 if (left) {
00329
00330
00331
00332 mi = *m - i__ + 1;
00333 ic = i__;
00334 } else {
00335
00336
00337
00338 ni = *n - i__ + 1;
00339 jc = i__;
00340 }
00341
00342
00343
00344 slarzb_(side, transt, "Backward", "Rowwise", &mi, &ni, &ib, l, &a[
00345 i__ + ja * a_dim1], lda, t, &c__65, &c__[ic + jc * c_dim1]
00346 , ldc, &work[1], &ldwork);
00347
00348 }
00349
00350 }
00351
00352 work[1] = (real) lwkopt;
00353
00354 return 0;
00355
00356
00357
00358 }