mirror of
				https://github.com/RetroDECK/Duckstation.git
				synced 2025-04-10 19:15:14 +00:00 
			
		
		
		
	
		
			
				
	
	
		
			91 lines
		
	
	
		
			3.8 KiB
		
	
	
	
		
			C++
		
	
	
	
	
	
			
		
		
	
	
			91 lines
		
	
	
		
			3.8 KiB
		
	
	
	
		
			C++
		
	
	
	
	
	
| ////////////////////////////////////////////////////////////////////////////////
 | |
| ///
 | |
| /// The routine detects highest value on an array of values and calculates the 
 | |
| /// precise peak location as a mass-center of the 'hump' around the peak value.
 | |
| ///
 | |
| /// Author        : Copyright (c) Olli Parviainen
 | |
| /// Author e-mail : oparviai 'at' iki.fi
 | |
| /// SoundTouch WWW: http://www.surina.net/soundtouch
 | |
| ///
 | |
| ////////////////////////////////////////////////////////////////////////////////
 | |
| //
 | |
| // License :
 | |
| //
 | |
| //  SoundTouch audio processing library
 | |
| //  Copyright (c) Olli Parviainen
 | |
| //
 | |
| //  This library is free software; you can redistribute it and/or
 | |
| //  modify it under the terms of the GNU Lesser General Public
 | |
| //  License as published by the Free Software Foundation; either
 | |
| //  version 2.1 of the License, or (at your option) any later version.
 | |
| //
 | |
| //  This library is distributed in the hope that it will be useful,
 | |
| //  but WITHOUT ANY WARRANTY; without even the implied warranty of
 | |
| //  MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
 | |
| //  Lesser General Public License for more details.
 | |
| //
 | |
| //  You should have received a copy of the GNU Lesser General Public
 | |
| //  License along with this library; if not, write to the Free Software
 | |
| //  Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA  02111-1307  USA
 | |
| //
 | |
| ////////////////////////////////////////////////////////////////////////////////
 | |
| 
 | |
| #ifndef _PeakFinder_H_
 | |
| #define _PeakFinder_H_
 | |
| 
 | |
| namespace soundtouch
 | |
| {
 | |
| 
 | |
| class PeakFinder
 | |
| {
 | |
| protected:
 | |
|     /// Min, max allowed peak positions within the data vector
 | |
|     int minPos, maxPos;
 | |
| 
 | |
|     /// Calculates the mass center between given vector items.
 | |
|     double calcMassCenter(const float *data, ///< Data vector.
 | |
|                          int firstPos,      ///< Index of first vector item belonging to the peak.
 | |
|                          int lastPos        ///< Index of last vector item belonging to the peak.
 | |
|                          ) const;
 | |
| 
 | |
|     /// Finds the data vector index where the monotoniously decreasing signal crosses the
 | |
|     /// given level.
 | |
|     int   findCrossingLevel(const float *data,  ///< Data vector.
 | |
|                             float level,        ///< Goal crossing level.
 | |
|                             int peakpos,        ///< Peak position index within the data vector.
 | |
|                             int direction       /// Direction where to proceed from the peak: 1 = right, -1 = left.
 | |
|                             ) const;
 | |
| 
 | |
|     // Finds real 'top' of a peak hump from neighnourhood of the given 'peakpos'.
 | |
|     int findTop(const float *data, int peakpos) const;
 | |
| 
 | |
| 
 | |
|     /// Finds the 'ground' level, i.e. smallest level between two neighbouring peaks, to right- 
 | |
|     /// or left-hand side of the given peak position.
 | |
|     int   findGround(const float *data,     /// Data vector.
 | |
|                      int peakpos,           /// Peak position index within the data vector.
 | |
|                      int direction          /// Direction where to proceed from the peak: 1 = right, -1 = left.
 | |
|                      ) const;
 | |
| 
 | |
|     /// get exact center of peak near given position by calculating local mass of center
 | |
|     double getPeakCenter(const float *data, int peakpos) const;
 | |
| 
 | |
| public:
 | |
|     /// Constructor. 
 | |
|     PeakFinder();
 | |
| 
 | |
|     /// Detect exact peak position of the data vector by finding the largest peak 'hump'
 | |
|     /// and calculating the mass-center location of the peak hump.
 | |
|     ///
 | |
|     /// \return The location of the largest base harmonic peak hump.
 | |
|     double detectPeak(const float *data, /// Data vector to be analyzed. The data vector has
 | |
|                                         /// to be at least 'maxPos' items long.
 | |
|                      int minPos,        ///< Min allowed peak location within the vector data.
 | |
|                      int maxPos         ///< Max allowed peak location within the vector data.
 | |
|                      );
 | |
| };
 | |
| 
 | |
| }
 | |
| 
 | |
| #endif // _PeakFinder_H_
 | 
