vnwrms.f 1.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142
  1. *DECK VNWRMS
  2. REAL FUNCTION VNWRMS (N, V, W)
  3. C***BEGIN PROLOGUE VNWRMS
  4. C***SUBSIDIARY
  5. C***PURPOSE Subsidiary to DEBDF
  6. C***LIBRARY SLATEC
  7. C***TYPE SINGLE PRECISION (VNWRMS-S, DVNRMS-D)
  8. C***AUTHOR (UNKNOWN)
  9. C***DESCRIPTION
  10. C
  11. C VNWRMS computes a weighted root-mean-square vector norm for the
  12. C integrator package DEBDF.
  13. C
  14. C***SEE ALSO DEBDF
  15. C***ROUTINES CALLED (NONE)
  16. C***REVISION HISTORY (YYMMDD)
  17. C 800901 DATE WRITTEN
  18. C 890531 Changed all specific intrinsics to generic. (WRB)
  19. C 890831 Modified array declarations. (WRB)
  20. C 891214 Prologue converted to Version 4.0 format. (BAB)
  21. C 900328 Added TYPE section. (WRB)
  22. C***END PROLOGUE VNWRMS
  23. C
  24. C
  25. CLLL. OPTIMIZE
  26. C-----------------------------------------------------------------------
  27. C THIS FUNCTION ROUTINE COMPUTES THE WEIGHTED ROOT-MEAN-SQUARE NORM
  28. C OF THE VECTOR OF LENGTH N CONTAINED IN THE ARRAY V, WITH WEIGHTS
  29. C CONTAINED IN THE ARRAY W OF LENGTH N..
  30. C VNWRMS = SQRT( (1/N) * SUM( V(I)/W(I) )**2 )
  31. C-----------------------------------------------------------------------
  32. INTEGER N, I
  33. REAL V, W, SUM
  34. DIMENSION V(*), W(*)
  35. C***FIRST EXECUTABLE STATEMENT VNWRMS
  36. SUM = 0.0E0
  37. DO 10 I = 1,N
  38. 10 SUM = SUM + (V(I)/W(I))**2
  39. VNWRMS = SQRT(SUM/N)
  40. RETURN
  41. C----------------------- END OF FUNCTION VNWRMS ------------------------
  42. END