00001
00002
00003
00004
00005
00006
00007
00008
00009
00010
00011
00012
00013
00014
00015 namespace ROOT {
00016
00017 namespace Minuit2 {
00018
00019
00020 bool mnlsame(const char*, const char*);
00021 int mnxerbla(const char*, int);
00022
00023 int Mndspmv(const char* uplo, unsigned int n, double alpha,
00024 const double* ap, const double* x, int incx, double beta,
00025 double* y, int incy) {
00026
00027 int i__1, i__2;
00028
00029
00030 int info;
00031 double temp1, temp2;
00032 int i__, j, k;
00033 int kk, ix, iy, jx, jy, kx, ky;
00034
00035
00036
00037
00038
00039
00040
00041
00042
00043
00044
00045
00046
00047
00048
00049
00050
00051
00052
00053
00054
00055
00056
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
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 --y;
00136 --x;
00137 --ap;
00138
00139
00140 info = 0;
00141 if (! mnlsame(uplo, "U") && ! mnlsame(uplo, "L")) {
00142 info = 1;
00143 }
00144
00145
00146
00147 else if (incx == 0) {
00148 info = 6;
00149 } else if (incy == 0) {
00150 info = 9;
00151 }
00152 if (info != 0) {
00153 mnxerbla("DSPMV ", info);
00154 return 0;
00155 }
00156
00157
00158
00159 if ( ( n == 0) || ( alpha == 0. && beta == 1.) ) {
00160 return 0;
00161 }
00162
00163
00164
00165 if (incx > 0) {
00166 kx = 1;
00167 } else {
00168 kx = 1 - (n - 1) * incx;
00169 }
00170 if (incy > 0) {
00171 ky = 1;
00172 } else {
00173 ky = 1 - (n - 1) * incy;
00174 }
00175
00176
00177
00178
00179
00180
00181 if (beta != 1.) {
00182 if (incy == 1) {
00183 if (beta == 0.) {
00184 i__1 = n;
00185 for (i__ = 1; i__ <= i__1; ++i__) {
00186 y[i__] = 0.;
00187
00188 }
00189 } else {
00190 i__1 = n;
00191 for (i__ = 1; i__ <= i__1; ++i__) {
00192 y[i__] = beta * y[i__];
00193
00194 }
00195 }
00196 } else {
00197 iy = ky;
00198 if (beta == 0.) {
00199 i__1 = n;
00200 for (i__ = 1; i__ <= i__1; ++i__) {
00201 y[iy] = 0.;
00202 iy += incy;
00203
00204 }
00205 } else {
00206 i__1 = n;
00207 for (i__ = 1; i__ <= i__1; ++i__) {
00208 y[iy] = beta * y[iy];
00209 iy += incy;
00210
00211 }
00212 }
00213 }
00214 }
00215 if (alpha == 0.) {
00216 return 0;
00217 }
00218 kk = 1;
00219 if (mnlsame(uplo, "U")) {
00220
00221
00222
00223 if (incx == 1 && incy == 1) {
00224 i__1 = n;
00225 for (j = 1; j <= i__1; ++j) {
00226 temp1 = alpha * x[j];
00227 temp2 = 0.;
00228 k = kk;
00229 i__2 = j - 1;
00230 for (i__ = 1; i__ <= i__2; ++i__) {
00231 y[i__] += temp1 * ap[k];
00232 temp2 += ap[k] * x[i__];
00233 ++k;
00234
00235 }
00236 y[j] = y[j] + temp1 * ap[kk + j - 1] + alpha * temp2;
00237 kk += j;
00238
00239 }
00240 } else {
00241 jx = kx;
00242 jy = ky;
00243 i__1 = n;
00244 for (j = 1; j <= i__1; ++j) {
00245 temp1 = alpha * x[jx];
00246 temp2 = 0.;
00247 ix = kx;
00248 iy = ky;
00249 i__2 = kk + j - 2;
00250 for (k = 0; k <= i__2 - kk; ++k) {
00251 y[iy] += temp1 * ap[k + kk];
00252 temp2 += ap[k + kk] * x[ix];
00253 ix += incx;
00254 iy += incy;
00255
00256 }
00257 y[jy] = y[jy] + temp1 * ap[kk + j - 1] + alpha * temp2;
00258 jx += incx;
00259 jy += incy;
00260 kk += j;
00261
00262 }
00263 }
00264 } else {
00265
00266
00267
00268 if (incx == 1 && incy == 1) {
00269 i__1 = n;
00270 for (j = 1; j <= i__1; ++j) {
00271 temp1 = alpha * x[j];
00272 temp2 = 0.;
00273 y[j] += temp1 * ap[kk];
00274 k = kk + 1;
00275 i__2 = n;
00276 for (i__ = j + 1; i__ <= i__2; ++i__) {
00277 y[i__] += temp1 * ap[k];
00278 temp2 += ap[k] * x[i__];
00279 ++k;
00280
00281 }
00282 y[j] += alpha * temp2;
00283 kk += n - j + 1;
00284
00285 }
00286 } else {
00287 jx = kx;
00288 jy = ky;
00289 i__1 = n;
00290 for (j = 1; j <= i__1; ++j) {
00291 temp1 = alpha * x[jx];
00292 temp2 = 0.;
00293 y[jy] += temp1 * ap[kk];
00294 ix = jx;
00295 iy = jy;
00296 i__2 = kk + n - j;
00297 for (k = kk + 1; k <= i__2; ++k) {
00298 ix += incx;
00299 iy += incy;
00300 y[iy] += temp1 * ap[k];
00301 temp2 += ap[k] * x[ix];
00302
00303 }
00304 y[jy] += alpha * temp2;
00305 jx += incx;
00306 jy += incy;
00307 kk += n - j + 1;
00308
00309 }
00310 }
00311 }
00312
00313 return 0;
00314
00315
00316
00317 }
00318
00319
00320 }
00321
00322 }