00001
00002
00003
00004
00005
00006
00007
00008
00009
00010
00011
00012
00013 #include "f2c.h"
00014 #include "blaswrap.h"
00015
00016
00017
00018 struct {
00019 integer infot, iounit;
00020 logical ok, lerr;
00021 } infoc_;
00022
00023 #define infoc_1 infoc_
00024
00025 struct {
00026 char srnamt[32];
00027 } srnamc_;
00028
00029 #define srnamc_1 srnamc_
00030
00031
00032
00033 static real c_b11 = 0.f;
00034 static real c_b16 = 1.f;
00035 static integer c__1 = 1;
00036
00037 int schkqp_(logical *dotype, integer *nm, integer *mval,
00038 integer *nn, integer *nval, real *thresh, logical *tsterr, real *a,
00039 real *copya, real *s, real *copys, real *tau, real *work, integer *
00040 iwork, integer *nout)
00041 {
00042
00043
00044 static integer iseedy[4] = { 1988,1989,1990,1991 };
00045
00046
00047 static char fmt_9999[] = "(\002 M =\002,i5,\002, N =\002,i5,\002, type"
00048 " \002,i2,\002, test \002,i2,\002, ratio =\002,g12.5)";
00049
00050
00051 integer i__1, i__2, i__3, i__4;
00052 real r__1;
00053
00054
00055 int s_copy(char *, char *, ftnlen, ftnlen);
00056 integer s_wsfe(cilist *), do_fio(integer *, char *, ftnlen), e_wsfe(void);
00057
00058
00059 integer i__, k, m, n, im, in, lda;
00060 real eps;
00061 integer mode, info;
00062 char path[3];
00063 integer ilow, nrun;
00064 extern int alahd_(integer *, char *);
00065 integer ihigh, nfail, iseed[4], imode, mnmin, istep;
00066 extern doublereal sqpt01_(integer *, integer *, integer *, real *, real *,
00067 integer *, real *, integer *, real *, integer *);
00068 integer nerrs;
00069 extern doublereal sqrt11_(integer *, integer *, real *, integer *, real *,
00070 real *, integer *);
00071 integer lwork;
00072 extern doublereal sqrt12_(integer *, integer *, real *, integer *, real *,
00073 real *, integer *), slamch_(char *);
00074 extern int alasum_(char *, integer *, integer *, integer
00075 *, integer *), slaord_(char *, integer *, real *, integer
00076 *), sgeqpf_(integer *, integer *, real *, integer *,
00077 integer *, real *, real *, integer *), slacpy_(char *, integer *,
00078 integer *, real *, integer *, real *, integer *), slaset_(
00079 char *, integer *, integer *, real *, real *, real *, integer *), slatms_(integer *, integer *, char *, integer *, char *,
00080 real *, integer *, real *, real *, integer *, integer *, char *,
00081 real *, integer *, real *, integer *),
00082 serrqp_(char *, integer *);
00083 real result[3];
00084
00085
00086 static cilist io___24 = { 0, 0, 0, fmt_9999, 0 };
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 --iwork;
00175 --work;
00176 --tau;
00177 --copys;
00178 --s;
00179 --copya;
00180 --a;
00181 --nval;
00182 --mval;
00183 --dotype;
00184
00185
00186
00187
00188
00189
00190
00191 s_copy(path, "Single precision", (ftnlen)1, (ftnlen)16);
00192 s_copy(path + 1, "QP", (ftnlen)2, (ftnlen)2);
00193 nrun = 0;
00194 nfail = 0;
00195 nerrs = 0;
00196 for (i__ = 1; i__ <= 4; ++i__) {
00197 iseed[i__ - 1] = iseedy[i__ - 1];
00198
00199 }
00200 eps = slamch_("Epsilon");
00201
00202
00203
00204 if (*tsterr) {
00205 serrqp_(path, nout);
00206 }
00207 infoc_1.infot = 0;
00208
00209 i__1 = *nm;
00210 for (im = 1; im <= i__1; ++im) {
00211
00212
00213
00214 m = mval[im];
00215 lda = max(1,m);
00216
00217 i__2 = *nn;
00218 for (in = 1; in <= i__2; ++in) {
00219
00220
00221
00222 n = nval[in];
00223 mnmin = min(m,n);
00224
00225 i__3 = 1, i__4 = m * max(m,n) + (mnmin << 2) + max(m,n), i__3 =
00226 max(i__3,i__4), i__4 = m * n + (mnmin << 1) + (n << 2);
00227 lwork = max(i__3,i__4);
00228
00229 for (imode = 1; imode <= 6; ++imode) {
00230 if (! dotype[imode]) {
00231 goto L60;
00232 }
00233
00234
00235
00236
00237
00238
00239
00240
00241
00242 mode = imode;
00243 if (imode > 3) {
00244 mode = 1;
00245 }
00246
00247
00248
00249
00250 i__3 = n;
00251 for (i__ = 1; i__ <= i__3; ++i__) {
00252 iwork[i__] = 0;
00253
00254 }
00255 if (imode == 1) {
00256 slaset_("Full", &m, &n, &c_b11, &c_b11, ©a[1], &lda);
00257 i__3 = mnmin;
00258 for (i__ = 1; i__ <= i__3; ++i__) {
00259 copys[i__] = 0.f;
00260
00261 }
00262 } else {
00263 r__1 = 1.f / eps;
00264 slatms_(&m, &n, "Uniform", iseed, "Nonsymm", ©s[1], &
00265 mode, &r__1, &c_b16, &m, &n, "No packing", ©a[
00266 1], &lda, &work[1], &info);
00267 if (imode >= 4) {
00268 if (imode == 4) {
00269 ilow = 1;
00270 istep = 1;
00271
00272 i__3 = 1, i__4 = n / 2;
00273 ihigh = max(i__3,i__4);
00274 } else if (imode == 5) {
00275
00276 i__3 = 1, i__4 = n / 2;
00277 ilow = max(i__3,i__4);
00278 istep = 1;
00279 ihigh = n;
00280 } else if (imode == 6) {
00281 ilow = 1;
00282 istep = 2;
00283 ihigh = n;
00284 }
00285 i__3 = ihigh;
00286 i__4 = istep;
00287 for (i__ = ilow; i__4 < 0 ? i__ >= i__3 : i__ <= i__3;
00288 i__ += i__4) {
00289 iwork[i__] = 1;
00290
00291 }
00292 }
00293 slaord_("Decreasing", &mnmin, ©s[1], &c__1);
00294 }
00295
00296
00297
00298 slacpy_("All", &m, &n, ©a[1], &lda, &a[1], &lda);
00299
00300
00301
00302 s_copy(srnamc_1.srnamt, "SGEQPF", (ftnlen)32, (ftnlen)6);
00303 sgeqpf_(&m, &n, &a[1], &lda, &iwork[1], &tau[1], &work[1], &
00304 info);
00305
00306
00307
00308 result[0] = sqrt12_(&m, &n, &a[1], &lda, ©s[1], &work[1],
00309 &lwork);
00310
00311
00312
00313 result[1] = sqpt01_(&m, &n, &mnmin, ©a[1], &a[1], &lda, &
00314 tau[1], &iwork[1], &work[1], &lwork);
00315
00316
00317
00318 result[2] = sqrt11_(&m, &mnmin, &a[1], &lda, &tau[1], &work[1]
00319 , &lwork);
00320
00321
00322
00323
00324 for (k = 1; k <= 3; ++k) {
00325 if (result[k - 1] >= *thresh) {
00326 if (nfail == 0 && nerrs == 0) {
00327 alahd_(nout, path);
00328 }
00329 io___24.ciunit = *nout;
00330 s_wsfe(&io___24);
00331 do_fio(&c__1, (char *)&m, (ftnlen)sizeof(integer));
00332 do_fio(&c__1, (char *)&n, (ftnlen)sizeof(integer));
00333 do_fio(&c__1, (char *)&imode, (ftnlen)sizeof(integer))
00334 ;
00335 do_fio(&c__1, (char *)&k, (ftnlen)sizeof(integer));
00336 do_fio(&c__1, (char *)&result[k - 1], (ftnlen)sizeof(
00337 real));
00338 e_wsfe();
00339 ++nfail;
00340 }
00341
00342 }
00343 nrun += 3;
00344 L60:
00345 ;
00346 }
00347
00348 }
00349
00350 }
00351
00352
00353
00354 alasum_(path, nout, &nfail, &nrun, &nerrs);
00355
00356
00357
00358
00359 return 0;
00360 }