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, nout;
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 integer c_n1 = -1;
00034 static integer c__0 = 0;
00035 static integer c__1 = 1;
00036 static integer c__2 = 2;
00037
00038 int zerrlq_(char *path, integer *nunit)
00039 {
00040
00041 integer i__1;
00042 doublereal d__1, d__2;
00043 doublecomplex z__1;
00044
00045
00046 integer s_wsle(cilist *), e_wsle(void);
00047 int s_copy(char *, char *, ftnlen, ftnlen);
00048
00049
00050 doublecomplex a[4] , b[2];
00051 integer i__, j;
00052 doublecomplex w[2], x[2], af[4] ;
00053 integer info;
00054 extern int zgelq2_(integer *, integer *, doublecomplex *,
00055 integer *, doublecomplex *, doublecomplex *, integer *), zungl2_(
00056 integer *, integer *, integer *, doublecomplex *, integer *,
00057 doublecomplex *, doublecomplex *, integer *), zunml2_(char *,
00058 char *, integer *, integer *, integer *, doublecomplex *, integer
00059 *, doublecomplex *, doublecomplex *, integer *, doublecomplex *,
00060 integer *), alaesm_(char *, logical *, integer *), chkxer_(char *, integer *, integer *, logical *, logical
00061 *), zgelqf_(integer *, integer *, doublecomplex *,
00062 integer *, doublecomplex *, doublecomplex *, integer *, integer *)
00063 , zgelqs_(integer *, integer *, integer *, doublecomplex *,
00064 integer *, doublecomplex *, doublecomplex *, integer *,
00065 doublecomplex *, integer *, integer *), zunglq_(integer *,
00066 integer *, integer *, doublecomplex *, integer *, doublecomplex *,
00067 doublecomplex *, integer *, integer *), zunmlq_(char *, char *,
00068 integer *, integer *, integer *, doublecomplex *, integer *,
00069 doublecomplex *, doublecomplex *, integer *, doublecomplex *,
00070 integer *, integer *);
00071
00072
00073 static cilist io___1 = { 0, 0, 0, 0, 0 };
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 infoc_1.nout = *nunit;
00118 io___1.ciunit = infoc_1.nout;
00119 s_wsle(&io___1);
00120 e_wsle();
00121
00122
00123
00124 for (j = 1; j <= 2; ++j) {
00125 for (i__ = 1; i__ <= 2; ++i__) {
00126 i__1 = i__ + (j << 1) - 3;
00127 d__1 = 1. / (doublereal) (i__ + j);
00128 d__2 = -1. / (doublereal) (i__ + j);
00129 z__1.r = d__1, z__1.i = d__2;
00130 a[i__1].r = z__1.r, a[i__1].i = z__1.i;
00131 i__1 = i__ + (j << 1) - 3;
00132 d__1 = 1. / (doublereal) (i__ + j);
00133 d__2 = -1. / (doublereal) (i__ + j);
00134 z__1.r = d__1, z__1.i = d__2;
00135 af[i__1].r = z__1.r, af[i__1].i = z__1.i;
00136
00137 }
00138 i__1 = j - 1;
00139 b[i__1].r = 0., b[i__1].i = 0.;
00140 i__1 = j - 1;
00141 w[i__1].r = 0., w[i__1].i = 0.;
00142 i__1 = j - 1;
00143 x[i__1].r = 0., x[i__1].i = 0.;
00144
00145 }
00146 infoc_1.ok = TRUE_;
00147
00148
00149
00150
00151
00152 s_copy(srnamc_1.srnamt, "ZGELQF", (ftnlen)32, (ftnlen)6);
00153 infoc_1.infot = 1;
00154 zgelqf_(&c_n1, &c__0, a, &c__1, b, w, &c__1, &info);
00155 chkxer_("ZGELQF", &infoc_1.infot, &infoc_1.nout, &infoc_1.lerr, &
00156 infoc_1.ok);
00157 infoc_1.infot = 2;
00158 zgelqf_(&c__0, &c_n1, a, &c__1, b, w, &c__1, &info);
00159 chkxer_("ZGELQF", &infoc_1.infot, &infoc_1.nout, &infoc_1.lerr, &
00160 infoc_1.ok);
00161 infoc_1.infot = 4;
00162 zgelqf_(&c__2, &c__1, a, &c__1, b, w, &c__2, &info);
00163 chkxer_("ZGELQF", &infoc_1.infot, &infoc_1.nout, &infoc_1.lerr, &
00164 infoc_1.ok);
00165 infoc_1.infot = 7;
00166 zgelqf_(&c__2, &c__1, a, &c__2, b, w, &c__1, &info);
00167 chkxer_("ZGELQF", &infoc_1.infot, &infoc_1.nout, &infoc_1.lerr, &
00168 infoc_1.ok);
00169
00170
00171
00172 s_copy(srnamc_1.srnamt, "ZGELQ2", (ftnlen)32, (ftnlen)6);
00173 infoc_1.infot = 1;
00174 zgelq2_(&c_n1, &c__0, a, &c__1, b, w, &info);
00175 chkxer_("ZGELQ2", &infoc_1.infot, &infoc_1.nout, &infoc_1.lerr, &
00176 infoc_1.ok);
00177 infoc_1.infot = 2;
00178 zgelq2_(&c__0, &c_n1, a, &c__1, b, w, &info);
00179 chkxer_("ZGELQ2", &infoc_1.infot, &infoc_1.nout, &infoc_1.lerr, &
00180 infoc_1.ok);
00181 infoc_1.infot = 4;
00182 zgelq2_(&c__2, &c__1, a, &c__1, b, w, &info);
00183 chkxer_("ZGELQ2", &infoc_1.infot, &infoc_1.nout, &infoc_1.lerr, &
00184 infoc_1.ok);
00185
00186
00187
00188 s_copy(srnamc_1.srnamt, "ZGELQS", (ftnlen)32, (ftnlen)6);
00189 infoc_1.infot = 1;
00190 zgelqs_(&c_n1, &c__0, &c__0, a, &c__1, x, b, &c__1, w, &c__1, &info);
00191 chkxer_("ZGELQS", &infoc_1.infot, &infoc_1.nout, &infoc_1.lerr, &
00192 infoc_1.ok);
00193 infoc_1.infot = 2;
00194 zgelqs_(&c__0, &c_n1, &c__0, a, &c__1, x, b, &c__1, w, &c__1, &info);
00195 chkxer_("ZGELQS", &infoc_1.infot, &infoc_1.nout, &infoc_1.lerr, &
00196 infoc_1.ok);
00197 infoc_1.infot = 2;
00198 zgelqs_(&c__2, &c__1, &c__0, a, &c__2, x, b, &c__1, w, &c__1, &info);
00199 chkxer_("ZGELQS", &infoc_1.infot, &infoc_1.nout, &infoc_1.lerr, &
00200 infoc_1.ok);
00201 infoc_1.infot = 3;
00202 zgelqs_(&c__0, &c__0, &c_n1, a, &c__1, x, b, &c__1, w, &c__1, &info);
00203 chkxer_("ZGELQS", &infoc_1.infot, &infoc_1.nout, &infoc_1.lerr, &
00204 infoc_1.ok);
00205 infoc_1.infot = 5;
00206 zgelqs_(&c__2, &c__2, &c__0, a, &c__1, x, b, &c__2, w, &c__1, &info);
00207 chkxer_("ZGELQS", &infoc_1.infot, &infoc_1.nout, &infoc_1.lerr, &
00208 infoc_1.ok);
00209 infoc_1.infot = 8;
00210 zgelqs_(&c__1, &c__2, &c__0, a, &c__1, x, b, &c__1, w, &c__1, &info);
00211 chkxer_("ZGELQS", &infoc_1.infot, &infoc_1.nout, &infoc_1.lerr, &
00212 infoc_1.ok);
00213 infoc_1.infot = 10;
00214 zgelqs_(&c__1, &c__1, &c__2, a, &c__1, x, b, &c__1, w, &c__1, &info);
00215 chkxer_("ZGELQS", &infoc_1.infot, &infoc_1.nout, &infoc_1.lerr, &
00216 infoc_1.ok);
00217
00218
00219
00220 s_copy(srnamc_1.srnamt, "ZUNGLQ", (ftnlen)32, (ftnlen)6);
00221 infoc_1.infot = 1;
00222 zunglq_(&c_n1, &c__0, &c__0, a, &c__1, x, w, &c__1, &info);
00223 chkxer_("ZUNGLQ", &infoc_1.infot, &infoc_1.nout, &infoc_1.lerr, &
00224 infoc_1.ok);
00225 infoc_1.infot = 2;
00226 zunglq_(&c__0, &c_n1, &c__0, a, &c__1, x, w, &c__1, &info);
00227 chkxer_("ZUNGLQ", &infoc_1.infot, &infoc_1.nout, &infoc_1.lerr, &
00228 infoc_1.ok);
00229 infoc_1.infot = 2;
00230 zunglq_(&c__2, &c__1, &c__0, a, &c__2, x, w, &c__2, &info);
00231 chkxer_("ZUNGLQ", &infoc_1.infot, &infoc_1.nout, &infoc_1.lerr, &
00232 infoc_1.ok);
00233 infoc_1.infot = 3;
00234 zunglq_(&c__0, &c__0, &c_n1, a, &c__1, x, w, &c__1, &info);
00235 chkxer_("ZUNGLQ", &infoc_1.infot, &infoc_1.nout, &infoc_1.lerr, &
00236 infoc_1.ok);
00237 infoc_1.infot = 3;
00238 zunglq_(&c__1, &c__1, &c__2, a, &c__1, x, w, &c__1, &info);
00239 chkxer_("ZUNGLQ", &infoc_1.infot, &infoc_1.nout, &infoc_1.lerr, &
00240 infoc_1.ok);
00241 infoc_1.infot = 5;
00242 zunglq_(&c__2, &c__2, &c__0, a, &c__1, x, w, &c__2, &info);
00243 chkxer_("ZUNGLQ", &infoc_1.infot, &infoc_1.nout, &infoc_1.lerr, &
00244 infoc_1.ok);
00245 infoc_1.infot = 8;
00246 zunglq_(&c__2, &c__2, &c__0, a, &c__2, x, w, &c__1, &info);
00247 chkxer_("ZUNGLQ", &infoc_1.infot, &infoc_1.nout, &infoc_1.lerr, &
00248 infoc_1.ok);
00249
00250
00251
00252 s_copy(srnamc_1.srnamt, "ZUNGL2", (ftnlen)32, (ftnlen)6);
00253 infoc_1.infot = 1;
00254 zungl2_(&c_n1, &c__0, &c__0, a, &c__1, x, w, &info);
00255 chkxer_("ZUNGL2", &infoc_1.infot, &infoc_1.nout, &infoc_1.lerr, &
00256 infoc_1.ok);
00257 infoc_1.infot = 2;
00258 zungl2_(&c__0, &c_n1, &c__0, a, &c__1, x, w, &info);
00259 chkxer_("ZUNGL2", &infoc_1.infot, &infoc_1.nout, &infoc_1.lerr, &
00260 infoc_1.ok);
00261 infoc_1.infot = 2;
00262 zungl2_(&c__2, &c__1, &c__0, a, &c__2, x, w, &info);
00263 chkxer_("ZUNGL2", &infoc_1.infot, &infoc_1.nout, &infoc_1.lerr, &
00264 infoc_1.ok);
00265 infoc_1.infot = 3;
00266 zungl2_(&c__0, &c__0, &c_n1, a, &c__1, x, w, &info);
00267 chkxer_("ZUNGL2", &infoc_1.infot, &infoc_1.nout, &infoc_1.lerr, &
00268 infoc_1.ok);
00269 infoc_1.infot = 3;
00270 zungl2_(&c__1, &c__1, &c__2, a, &c__1, x, w, &info);
00271 chkxer_("ZUNGL2", &infoc_1.infot, &infoc_1.nout, &infoc_1.lerr, &
00272 infoc_1.ok);
00273 infoc_1.infot = 5;
00274 zungl2_(&c__2, &c__2, &c__0, a, &c__1, x, w, &info);
00275 chkxer_("ZUNGL2", &infoc_1.infot, &infoc_1.nout, &infoc_1.lerr, &
00276 infoc_1.ok);
00277
00278
00279
00280 s_copy(srnamc_1.srnamt, "ZUNMLQ", (ftnlen)32, (ftnlen)6);
00281 infoc_1.infot = 1;
00282 zunmlq_("/", "N", &c__0, &c__0, &c__0, a, &c__1, x, af, &c__1, w, &c__1, &
00283 info);
00284 chkxer_("ZUNMLQ", &infoc_1.infot, &infoc_1.nout, &infoc_1.lerr, &
00285 infoc_1.ok);
00286 infoc_1.infot = 2;
00287 zunmlq_("L", "/", &c__0, &c__0, &c__0, a, &c__1, x, af, &c__1, w, &c__1, &
00288 info);
00289 chkxer_("ZUNMLQ", &infoc_1.infot, &infoc_1.nout, &infoc_1.lerr, &
00290 infoc_1.ok);
00291 infoc_1.infot = 3;
00292 zunmlq_("L", "N", &c_n1, &c__0, &c__0, a, &c__1, x, af, &c__1, w, &c__1, &
00293 info);
00294 chkxer_("ZUNMLQ", &infoc_1.infot, &infoc_1.nout, &infoc_1.lerr, &
00295 infoc_1.ok);
00296 infoc_1.infot = 4;
00297 zunmlq_("L", "N", &c__0, &c_n1, &c__0, a, &c__1, x, af, &c__1, w, &c__1, &
00298 info);
00299 chkxer_("ZUNMLQ", &infoc_1.infot, &infoc_1.nout, &infoc_1.lerr, &
00300 infoc_1.ok);
00301 infoc_1.infot = 5;
00302 zunmlq_("L", "N", &c__0, &c__0, &c_n1, a, &c__1, x, af, &c__1, w, &c__1, &
00303 info);
00304 chkxer_("ZUNMLQ", &infoc_1.infot, &infoc_1.nout, &infoc_1.lerr, &
00305 infoc_1.ok);
00306 infoc_1.infot = 5;
00307 zunmlq_("L", "N", &c__0, &c__1, &c__1, a, &c__1, x, af, &c__1, w, &c__1, &
00308 info);
00309 chkxer_("ZUNMLQ", &infoc_1.infot, &infoc_1.nout, &infoc_1.lerr, &
00310 infoc_1.ok);
00311 infoc_1.infot = 5;
00312 zunmlq_("R", "N", &c__1, &c__0, &c__1, a, &c__1, x, af, &c__1, w, &c__1, &
00313 info);
00314 chkxer_("ZUNMLQ", &infoc_1.infot, &infoc_1.nout, &infoc_1.lerr, &
00315 infoc_1.ok);
00316 infoc_1.infot = 7;
00317 zunmlq_("L", "N", &c__2, &c__0, &c__2, a, &c__1, x, af, &c__2, w, &c__1, &
00318 info);
00319 chkxer_("ZUNMLQ", &infoc_1.infot, &infoc_1.nout, &infoc_1.lerr, &
00320 infoc_1.ok);
00321 infoc_1.infot = 7;
00322 zunmlq_("R", "N", &c__0, &c__2, &c__2, a, &c__1, x, af, &c__1, w, &c__1, &
00323 info);
00324 chkxer_("ZUNMLQ", &infoc_1.infot, &infoc_1.nout, &infoc_1.lerr, &
00325 infoc_1.ok);
00326 infoc_1.infot = 10;
00327 zunmlq_("L", "N", &c__2, &c__1, &c__0, a, &c__2, x, af, &c__1, w, &c__1, &
00328 info);
00329 chkxer_("ZUNMLQ", &infoc_1.infot, &infoc_1.nout, &infoc_1.lerr, &
00330 infoc_1.ok);
00331 infoc_1.infot = 12;
00332 zunmlq_("L", "N", &c__1, &c__2, &c__0, a, &c__1, x, af, &c__1, w, &c__1, &
00333 info);
00334 chkxer_("ZUNMLQ", &infoc_1.infot, &infoc_1.nout, &infoc_1.lerr, &
00335 infoc_1.ok);
00336 infoc_1.infot = 12;
00337 zunmlq_("R", "N", &c__2, &c__1, &c__0, a, &c__1, x, af, &c__2, w, &c__1, &
00338 info);
00339 chkxer_("ZUNMLQ", &infoc_1.infot, &infoc_1.nout, &infoc_1.lerr, &
00340 infoc_1.ok);
00341
00342
00343
00344 s_copy(srnamc_1.srnamt, "ZUNML2", (ftnlen)32, (ftnlen)6);
00345 infoc_1.infot = 1;
00346 zunml2_("/", "N", &c__0, &c__0, &c__0, a, &c__1, x, af, &c__1, w, &info);
00347 chkxer_("ZUNML2", &infoc_1.infot, &infoc_1.nout, &infoc_1.lerr, &
00348 infoc_1.ok);
00349 infoc_1.infot = 2;
00350 zunml2_("L", "/", &c__0, &c__0, &c__0, a, &c__1, x, af, &c__1, w, &info);
00351 chkxer_("ZUNML2", &infoc_1.infot, &infoc_1.nout, &infoc_1.lerr, &
00352 infoc_1.ok);
00353 infoc_1.infot = 3;
00354 zunml2_("L", "N", &c_n1, &c__0, &c__0, a, &c__1, x, af, &c__1, w, &info);
00355 chkxer_("ZUNML2", &infoc_1.infot, &infoc_1.nout, &infoc_1.lerr, &
00356 infoc_1.ok);
00357 infoc_1.infot = 4;
00358 zunml2_("L", "N", &c__0, &c_n1, &c__0, a, &c__1, x, af, &c__1, w, &info);
00359 chkxer_("ZUNML2", &infoc_1.infot, &infoc_1.nout, &infoc_1.lerr, &
00360 infoc_1.ok);
00361 infoc_1.infot = 5;
00362 zunml2_("L", "N", &c__0, &c__0, &c_n1, a, &c__1, x, af, &c__1, w, &info);
00363 chkxer_("ZUNML2", &infoc_1.infot, &infoc_1.nout, &infoc_1.lerr, &
00364 infoc_1.ok);
00365 infoc_1.infot = 5;
00366 zunml2_("L", "N", &c__0, &c__1, &c__1, a, &c__1, x, af, &c__1, w, &info);
00367 chkxer_("ZUNML2", &infoc_1.infot, &infoc_1.nout, &infoc_1.lerr, &
00368 infoc_1.ok);
00369 infoc_1.infot = 5;
00370 zunml2_("R", "N", &c__1, &c__0, &c__1, a, &c__1, x, af, &c__1, w, &info);
00371 chkxer_("ZUNML2", &infoc_1.infot, &infoc_1.nout, &infoc_1.lerr, &
00372 infoc_1.ok);
00373 infoc_1.infot = 7;
00374 zunml2_("L", "N", &c__2, &c__1, &c__2, a, &c__1, x, af, &c__2, w, &info);
00375 chkxer_("ZUNML2", &infoc_1.infot, &infoc_1.nout, &infoc_1.lerr, &
00376 infoc_1.ok);
00377 infoc_1.infot = 7;
00378 zunml2_("R", "N", &c__1, &c__2, &c__2, a, &c__1, x, af, &c__1, w, &info);
00379 chkxer_("ZUNML2", &infoc_1.infot, &infoc_1.nout, &infoc_1.lerr, &
00380 infoc_1.ok);
00381 infoc_1.infot = 10;
00382 zunml2_("L", "N", &c__2, &c__1, &c__0, a, &c__2, x, af, &c__1, w, &info);
00383 chkxer_("ZUNML2", &infoc_1.infot, &infoc_1.nout, &infoc_1.lerr, &
00384 infoc_1.ok);
00385
00386
00387
00388 alaesm_(path, &infoc_1.ok, &infoc_1.nout);
00389
00390 return 0;
00391
00392
00393
00394 }