home *** CD-ROM | disk | FTP | other *** search
/ Geek Gadgets 1 / ADE-1.bin / ade-dist / octave-1.1.1p1-src.tgz / tar.out / fsf / octave / libcruft / blas / ddot.f < prev    next >
Text File  |  1996-09-28  |  1KB  |  49 lines

  1.       DOUBLE PRECISION FUNCTION DDOT(N,DX,INCX,DY,INCY)
  2. C
  3. C     FORMS THE DOT PRODUCT OF TWO VECTORS.
  4. C     USES UNROLLED LOOPS FOR INCREMENTS EQUAL TO ONE.
  5. C     JACK DONGARRA, LINPACK, 3/11/78.
  6. C
  7.       DOUBLE PRECISION DX(1),DY(1),DTEMP
  8.       INTEGER I,INCX,INCY,IX,IY,M,MP1,N
  9. C
  10.       DDOT = 0.0D0
  11.       DTEMP = 0.0D0
  12.       IF(N.LE.0)RETURN
  13.       IF(INCX.EQ.1.AND.INCY.EQ.1)GO TO 20
  14. C
  15. C        CODE FOR UNEQUAL INCREMENTS OR EQUAL INCREMENTS
  16. C          NOT EQUAL TO 1
  17. C
  18.       IX = 1
  19.       IY = 1
  20.       IF(INCX.LT.0)IX = (-N+1)*INCX + 1
  21.       IF(INCY.LT.0)IY = (-N+1)*INCY + 1
  22.       DO 10 I = 1,N
  23.         DTEMP = DTEMP + DX(IX)*DY(IY)
  24.         IX = IX + INCX
  25.         IY = IY + INCY
  26.    10 CONTINUE
  27.       DDOT = DTEMP
  28.       RETURN
  29. C
  30. C        CODE FOR BOTH INCREMENTS EQUAL TO 1
  31. C
  32. C
  33. C        CLEAN-UP LOOP
  34. C
  35.    20 M = MOD(N,5)
  36.       IF( M .EQ. 0 ) GO TO 40
  37.       DO 30 I = 1,M
  38.         DTEMP = DTEMP + DX(I)*DY(I)
  39.    30 CONTINUE
  40.       IF( N .LT. 5 ) GO TO 60
  41.    40 MP1 = M + 1
  42.       DO 50 I = MP1,N,5
  43.         DTEMP = DTEMP + DX(I)*DY(I) + DX(I + 1)*DY(I + 1) +
  44.      *   DX(I + 2)*DY(I + 2) + DX(I + 3)*DY(I + 3) + DX(I + 4)*DY(I + 4)
  45.    50 CONTINUE
  46.    60 DDOT = DTEMP
  47.       RETURN
  48.       END
  49.