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__0 = 0;
00034 static integer c__1 = 1;
00035 static doublereal c_b9 = -1.;
00036 static integer c_n1 = -1;
00037 static integer c__2 = 2;
00038 
00039  int derrps_(char *path, integer *nunit)
00040 {
00041     
00042     integer s_wsle(cilist *), e_wsle(void);
00043      int s_copy(char *, char *, ftnlen, ftnlen);
00044 
00045     
00046     doublereal a[16]    ;
00047     integer i__, j, piv[4], info;
00048     doublereal work[8];
00049     extern  int dpstf2_(char *, integer *, doublereal *, 
00050             integer *, integer *, integer *, doublereal *, doublereal *, 
00051             integer *), alaesm_(char *, logical *, integer *),
00052              chkxer_(char *, integer *, integer *, logical *, logical *), dpstrf_(char *, integer *, doublereal *, integer *, 
00053             integer *, integer *, doublereal *, doublereal *, integer *);
00054 
00055     
00056     static cilist io___1 = { 0, 0, 0, 0, 0 };
00057 
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     infoc_1.nout = *nunit;
00101     io___1.ciunit = infoc_1.nout;
00102     s_wsle(&io___1);
00103     e_wsle();
00104 
00105 
00106 
00107     for (j = 1; j <= 4; ++j) {
00108         for (i__ = 1; i__ <= 4; ++i__) {
00109             a[i__ + (j << 2) - 5] = 1. / (doublereal) (i__ + j);
00110 
00111 
00112         }
00113         piv[j - 1] = j;
00114         work[j - 1] = 0.;
00115         work[j + 3] = 0.;
00116 
00117 
00118     }
00119     infoc_1.ok = TRUE_;
00120 
00121 
00122 
00123 
00124 
00125 
00126 
00127     s_copy(srnamc_1.srnamt, "DPSTRF", (ftnlen)32, (ftnlen)6);
00128     infoc_1.infot = 1;
00129     dpstrf_("/", &c__0, a, &c__1, piv, &c__1, &c_b9, work, &info);
00130     chkxer_("DPSTRF", &infoc_1.infot, &infoc_1.nout, &infoc_1.lerr, &
00131             infoc_1.ok);
00132     infoc_1.infot = 2;
00133     dpstrf_("U", &c_n1, a, &c__1, piv, &c__1, &c_b9, work, &info);
00134     chkxer_("DPSTRF", &infoc_1.infot, &infoc_1.nout, &infoc_1.lerr, &
00135             infoc_1.ok);
00136     infoc_1.infot = 4;
00137     dpstrf_("U", &c__2, a, &c__1, piv, &c__1, &c_b9, work, &info);
00138     chkxer_("DPSTRF", &infoc_1.infot, &infoc_1.nout, &infoc_1.lerr, &
00139             infoc_1.ok);
00140 
00141 
00142 
00143     s_copy(srnamc_1.srnamt, "DPSTF2", (ftnlen)32, (ftnlen)6);
00144     infoc_1.infot = 1;
00145     dpstf2_("/", &c__0, a, &c__1, piv, &c__1, &c_b9, work, &info);
00146     chkxer_("DPSTF2", &infoc_1.infot, &infoc_1.nout, &infoc_1.lerr, &
00147             infoc_1.ok);
00148     infoc_1.infot = 2;
00149     dpstf2_("U", &c_n1, a, &c__1, piv, &c__1, &c_b9, work, &info);
00150     chkxer_("DPSTF2", &infoc_1.infot, &infoc_1.nout, &infoc_1.lerr, &
00151             infoc_1.ok);
00152     infoc_1.infot = 4;
00153     dpstf2_("U", &c__2, a, &c__1, piv, &c__1, &c_b9, work, &info);
00154     chkxer_("DPSTF2", &infoc_1.infot, &infoc_1.nout, &infoc_1.lerr, &
00155             infoc_1.ok);
00156 
00157 
00158 
00159 
00160     alaesm_(path, &infoc_1.ok, &infoc_1.nout);
00161 
00162     return 0;
00163 
00164 
00165 
00166 }