00001
00002
00003
00004
00005
00006
00007
00008
00009
00010
00011
00012
00013
00014
00015 namespace ROOT {
00016
00017 namespace Minuit2 {
00018
00019
00020 double mnddot(unsigned int n, const double* dx, int incx, const double* dy,
00021 int incy) {
00022
00023 int i__1;
00024 double ret_val;
00025
00026
00027 int i__, m;
00028 double dtemp;
00029 int ix, iy, mp1;
00030
00031
00032
00033
00034
00035
00036
00037
00038
00039 --dy;
00040 --dx;
00041
00042
00043 ret_val = 0.;
00044 dtemp = 0.;
00045 if (n <= 0) {
00046 return ret_val;
00047 }
00048 if (incx == 1 && incy == 1) {
00049 goto L20;
00050 }
00051
00052
00053
00054
00055 ix = 1;
00056 iy = 1;
00057 if (incx < 0) {
00058 ix = (-static_cast<int>(n) + 1) * incx + 1;
00059 }
00060 if (incy < 0) {
00061 iy = (-static_cast<int>(n) + 1) * incy + 1;
00062 }
00063 i__1 = n;
00064 for (i__ = 1; i__ <= i__1; ++i__) {
00065 dtemp += dx[ix] * dy[iy];
00066 ix += incx;
00067 iy += incy;
00068
00069 }
00070 ret_val = dtemp;
00071 return ret_val;
00072
00073
00074
00075
00076
00077
00078 L20:
00079 m = n % 5;
00080 if (m == 0) {
00081 goto L40;
00082 }
00083 i__1 = m;
00084 for (i__ = 1; i__ <= i__1; ++i__) {
00085 dtemp += dx[i__] * dy[i__];
00086
00087 }
00088 if (n < 5) {
00089 goto L60;
00090 }
00091 L40:
00092 mp1 = m + 1;
00093 i__1 = n;
00094 for (i__ = mp1; i__ <= i__1; i__ += 5) {
00095 dtemp = dtemp + dx[i__] * dy[i__] + dx[i__ + 1] * dy[i__ + 1] + dx[
00096 i__ + 2] * dy[i__ + 2] + dx[i__ + 3] * dy[i__ + 3] + dx[i__ +
00097 4] * dy[i__ + 4];
00098
00099 }
00100 L60:
00101 ret_val = dtemp;
00102 return ret_val;
00103 }
00104
00105
00106 }
00107
00108 }