mirror of
				https://github.com/saitohirga/WSJT-X.git
				synced 2025-10-25 10:00:23 -04:00 
			
		
		
		
	Added sort.f, ssort.f
git-svn-id: svn+ssh://svn.code.sf.net/p/wsjt/wsjt/trunk@36 ab8295b8-cf94-4d9e-aec4-7959e3be5d79
This commit is contained in:
		
							parent
							
								
									860e9d8c1a
								
							
						
					
					
						commit
						25c039f672
					
				
							
								
								
									
										4
									
								
								sort.f
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										4
									
								
								sort.f
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,4 @@ | |||||||
|  |       subroutine sort(n,arr) | ||||||
|  |       call ssort(arr,tmp,n,1) | ||||||
|  |       return | ||||||
|  |       end | ||||||
							
								
								
									
										285
									
								
								ssort.f
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										285
									
								
								ssort.f
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,285 @@ | |||||||
|  |       subroutine ssort (x,y,n,kflag) | ||||||
|  | c***purpose  sort an array and optionally make the same interchanges in | ||||||
|  | c            an auxiliary array.  the array may be sorted in increasing | ||||||
|  | c            or decreasing order.  a slightly modified quicksort | ||||||
|  | c            algorithm is used. | ||||||
|  | c | ||||||
|  | c   ssort sorts array x and optionally makes the same interchanges in | ||||||
|  | c   array y.  the array x may be sorted in increasing order or | ||||||
|  | c   decreasing order.  a slightly modified quicksort algorithm is used. | ||||||
|  | c | ||||||
|  | c   description of parameters | ||||||
|  | c      x - array of values to be sorted | ||||||
|  | c      y - array to be (optionally) carried along | ||||||
|  | c      n - number of values in array x to be sorted | ||||||
|  | c      kflag - control parameter | ||||||
|  | c            =  2  means sort x in increasing order and carry y along. | ||||||
|  | c            =  1  means sort x in increasing order (ignoring y) | ||||||
|  | c            = -1  means sort x in decreasing order (ignoring y) | ||||||
|  | c            = -2  means sort x in decreasing order and carry y along. | ||||||
|  | 
 | ||||||
|  |       integer kflag, n | ||||||
|  |       real x(*), y(*) | ||||||
|  |       real r, t, tt, tty, ty | ||||||
|  |       integer i, ij, j, k, kk, l, m, nn | ||||||
|  |       integer il(21), iu(21) | ||||||
|  | 
 | ||||||
|  |       nn = n | ||||||
|  |       if (nn .lt. 1) then | ||||||
|  |          print *, | ||||||
|  |      +      'the number of values to be sorted is not positive.' | ||||||
|  |          return | ||||||
|  |       endif | ||||||
|  | c | ||||||
|  |       kk = abs(kflag) | ||||||
|  |       if (kk.ne.1 .and. kk.ne.2) then | ||||||
|  |          print *, | ||||||
|  |      +      'the sort control parameter, k, is not 2, 1, -1, or -2.' | ||||||
|  |          return | ||||||
|  |       endif | ||||||
|  | c | ||||||
|  | c     alter array x to get decreasing order if needed | ||||||
|  | c | ||||||
|  |       if (kflag .le. -1) then | ||||||
|  |          do 10 i=1,nn | ||||||
|  |             x(i) = -x(i) | ||||||
|  |    10    continue | ||||||
|  |       endif | ||||||
|  | c | ||||||
|  |       if (kk .eq. 2) go to 100 | ||||||
|  | c | ||||||
|  | c     sort x only | ||||||
|  | c | ||||||
|  |       m = 1 | ||||||
|  |       i = 1 | ||||||
|  |       j = nn | ||||||
|  |       r = 0.375e0 | ||||||
|  | c | ||||||
|  |    20 if (i .eq. j) go to 60 | ||||||
|  |       if (r .le. 0.5898437e0) then | ||||||
|  |          r = r+3.90625e-2 | ||||||
|  |       else | ||||||
|  |          r = r-0.21875e0 | ||||||
|  |       endif | ||||||
|  | c | ||||||
|  |    30 k = i | ||||||
|  | c | ||||||
|  | c     select a central element of the array and save it in location t | ||||||
|  | c | ||||||
|  |       ij = i + int((j-i)*r) | ||||||
|  |       t = x(ij) | ||||||
|  | c | ||||||
|  | c     if first element of array is greater than t, interchange with t | ||||||
|  | c | ||||||
|  |       if (x(i) .gt. t) then | ||||||
|  |          x(ij) = x(i) | ||||||
|  |          x(i) = t | ||||||
|  |          t = x(ij) | ||||||
|  |       endif | ||||||
|  |       l = j | ||||||
|  | c | ||||||
|  | c     if last element of array is less than than t, interchange with t | ||||||
|  | c | ||||||
|  |       if (x(j) .lt. t) then | ||||||
|  |          x(ij) = x(j) | ||||||
|  |          x(j) = t | ||||||
|  |          t = x(ij) | ||||||
|  | c | ||||||
|  | c        if first element of array is greater than t, interchange with t | ||||||
|  | c | ||||||
|  |          if (x(i) .gt. t) then | ||||||
|  |             x(ij) = x(i) | ||||||
|  |             x(i) = t | ||||||
|  |             t = x(ij) | ||||||
|  |          endif | ||||||
|  |       endif | ||||||
|  | c | ||||||
|  | c     find an element in the second half of the array which is smaller | ||||||
|  | c     than t | ||||||
|  | c | ||||||
|  |    40 l = l-1 | ||||||
|  |       if (x(l) .gt. t) go to 40 | ||||||
|  | c | ||||||
|  | c     find an element in the first half of the array which is greater | ||||||
|  | c     than t | ||||||
|  | c | ||||||
|  |    50 k = k+1 | ||||||
|  |       if (x(k) .lt. t) go to 50 | ||||||
|  | c | ||||||
|  | c     interchange these elements | ||||||
|  | c | ||||||
|  |       if (k .le. l) then | ||||||
|  |          tt = x(l) | ||||||
|  |          x(l) = x(k) | ||||||
|  |          x(k) = tt | ||||||
|  |          go to 40 | ||||||
|  |       endif | ||||||
|  | c | ||||||
|  | c     save upper and lower subscripts of the array yet to be sorted | ||||||
|  | c | ||||||
|  |       if (l-i .gt. j-k) then | ||||||
|  |          il(m) = i | ||||||
|  |          iu(m) = l | ||||||
|  |          i = k | ||||||
|  |          m = m+1 | ||||||
|  |       else | ||||||
|  |          il(m) = k | ||||||
|  |          iu(m) = j | ||||||
|  |          j = l | ||||||
|  |          m = m+1 | ||||||
|  |       endif | ||||||
|  |       go to 70 | ||||||
|  | c | ||||||
|  | c     begin again on another portion of the unsorted array | ||||||
|  | c | ||||||
|  |    60 m = m-1 | ||||||
|  |       if (m .eq. 0) go to 190 | ||||||
|  |       i = il(m) | ||||||
|  |       j = iu(m) | ||||||
|  | c | ||||||
|  |    70 if (j-i .ge. 1) go to 30 | ||||||
|  |       if (i .eq. 1) go to 20 | ||||||
|  |       i = i-1 | ||||||
|  | c | ||||||
|  |    80 i = i+1 | ||||||
|  |       if (i .eq. j) go to 60 | ||||||
|  |       t = x(i+1) | ||||||
|  |       if (x(i) .le. t) go to 80 | ||||||
|  |       k = i | ||||||
|  | c | ||||||
|  |    90 x(k+1) = x(k) | ||||||
|  |       k = k-1 | ||||||
|  |       if (t .lt. x(k)) go to 90 | ||||||
|  |       x(k+1) = t | ||||||
|  |       go to 80 | ||||||
|  | c | ||||||
|  | c     sort x and carry y along | ||||||
|  | c | ||||||
|  |   100 m = 1 | ||||||
|  |       i = 1 | ||||||
|  |       j = nn | ||||||
|  |       r = 0.375e0 | ||||||
|  | c | ||||||
|  |   110 if (i .eq. j) go to 150 | ||||||
|  |       if (r .le. 0.5898437e0) then | ||||||
|  |          r = r+3.90625e-2 | ||||||
|  |       else | ||||||
|  |          r = r-0.21875e0 | ||||||
|  |       endif | ||||||
|  | c | ||||||
|  |   120 k = i | ||||||
|  | c | ||||||
|  | c     select a central element of the array and save it in location t | ||||||
|  | c | ||||||
|  |       ij = i + int((j-i)*r) | ||||||
|  |       t = x(ij) | ||||||
|  |       ty = y(ij) | ||||||
|  | c | ||||||
|  | c     if first element of array is greater than t, interchange with t | ||||||
|  | c | ||||||
|  |       if (x(i) .gt. t) then | ||||||
|  |          x(ij) = x(i) | ||||||
|  |          x(i) = t | ||||||
|  |          t = x(ij) | ||||||
|  |          y(ij) = y(i) | ||||||
|  |          y(i) = ty | ||||||
|  |          ty = y(ij) | ||||||
|  |       endif | ||||||
|  |       l = j | ||||||
|  | c | ||||||
|  | c     if last element of array is less than t, interchange with t | ||||||
|  | c | ||||||
|  |       if (x(j) .lt. t) then | ||||||
|  |          x(ij) = x(j) | ||||||
|  |          x(j) = t | ||||||
|  |          t = x(ij) | ||||||
|  |          y(ij) = y(j) | ||||||
|  |          y(j) = ty | ||||||
|  |          ty = y(ij) | ||||||
|  | c | ||||||
|  | c        if first element of array is greater than t, interchange with t | ||||||
|  | c | ||||||
|  |          if (x(i) .gt. t) then | ||||||
|  |             x(ij) = x(i) | ||||||
|  |             x(i) = t | ||||||
|  |             t = x(ij) | ||||||
|  |             y(ij) = y(i) | ||||||
|  |             y(i) = ty | ||||||
|  |             ty = y(ij) | ||||||
|  |          endif | ||||||
|  |       endif | ||||||
|  | c | ||||||
|  | c     find an element in the second half of the array which is smaller | ||||||
|  | c     than t | ||||||
|  | c | ||||||
|  |   130 l = l-1 | ||||||
|  |       if (x(l) .gt. t) go to 130 | ||||||
|  | c | ||||||
|  | c     find an element in the first half of the array which is greater | ||||||
|  | c     than t | ||||||
|  | c | ||||||
|  |   140 k = k+1 | ||||||
|  |       if (x(k) .lt. t) go to 140 | ||||||
|  | c | ||||||
|  | c     interchange these elements | ||||||
|  | c | ||||||
|  |       if (k .le. l) then | ||||||
|  |          tt = x(l) | ||||||
|  |          x(l) = x(k) | ||||||
|  |          x(k) = tt | ||||||
|  |          tty = y(l) | ||||||
|  |          y(l) = y(k) | ||||||
|  |          y(k) = tty | ||||||
|  |          go to 130 | ||||||
|  |       endif | ||||||
|  | c | ||||||
|  | c     save upper and lower subscripts of the array yet to be sorted | ||||||
|  | c | ||||||
|  |       if (l-i .gt. j-k) then | ||||||
|  |          il(m) = i | ||||||
|  |          iu(m) = l | ||||||
|  |          i = k | ||||||
|  |          m = m+1 | ||||||
|  |       else | ||||||
|  |          il(m) = k | ||||||
|  |          iu(m) = j | ||||||
|  |          j = l | ||||||
|  |          m = m+1 | ||||||
|  |       endif | ||||||
|  |       go to 160 | ||||||
|  | c | ||||||
|  | c     begin again on another portion of the unsorted array | ||||||
|  | c | ||||||
|  |   150 m = m-1 | ||||||
|  |       if (m .eq. 0) go to 190 | ||||||
|  |       i = il(m) | ||||||
|  |       j = iu(m) | ||||||
|  | c | ||||||
|  |   160 if (j-i .ge. 1) go to 120 | ||||||
|  |       if (i .eq. 1) go to 110 | ||||||
|  |       i = i-1 | ||||||
|  | c | ||||||
|  |   170 i = i+1 | ||||||
|  |       if (i .eq. j) go to 150 | ||||||
|  |       t = x(i+1) | ||||||
|  |       ty = y(i+1) | ||||||
|  |       if (x(i) .le. t) go to 170 | ||||||
|  |       k = i | ||||||
|  | c | ||||||
|  |   180 x(k+1) = x(k) | ||||||
|  |       y(k+1) = y(k) | ||||||
|  |       k = k-1 | ||||||
|  |       if (t .lt. x(k)) go to 180 | ||||||
|  |       x(k+1) = t | ||||||
|  |       y(k+1) = ty | ||||||
|  |       go to 170 | ||||||
|  | c | ||||||
|  | c     clean up | ||||||
|  | c | ||||||
|  |   190 if (kflag .le. -1) then | ||||||
|  |          do 200 i=1,nn | ||||||
|  |             x(i) = -x(i) | ||||||
|  |   200    continue | ||||||
|  |       endif | ||||||
|  |       return | ||||||
|  |       end | ||||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user