mirror of
				https://github.com/f4exb/sdrangel.git
				synced 2025-10-25 18:10:22 -04:00 
			
		
		
		
	NFM Modulator: use CW smoother
This commit is contained in:
		
							parent
							
								
									1186e80663
								
							
						
					
					
						commit
						380eceaae5
					
				| @ -73,6 +73,7 @@ NFMMod::NFMMod() : | ||||
|     m_cwKeyer.setSampleRate(m_config.m_audioSampleRate); | ||||
|     m_cwKeyer.setWPM(13); | ||||
|     m_cwKeyer.setMode(CWKeyer::CWNone); | ||||
|     m_cwSmoother.setNbFadeSamples(96); // 2 ms @ 48 kHz
 | ||||
| } | ||||
| 
 | ||||
| NFMMod::~NFMMod() | ||||
| @ -188,14 +189,24 @@ void NFMMod::pullAF(Real& sample) | ||||
|         sample = ((audioSample[0] + audioSample[1])  / 65536.0f) * m_running.m_volumeFactor; | ||||
|         break; | ||||
|     case NFMModInputCWTone: | ||||
|         Real fadeFactor; | ||||
| 
 | ||||
|         if (m_cwKeyer.getSample()) | ||||
|         { | ||||
|             sample = m_toneNco.next(); | ||||
|             m_cwSmoother.getFadeSample(true, fadeFactor); | ||||
|             sample = m_toneNco.next() * fadeFactor; | ||||
|         } | ||||
|         else | ||||
|         { | ||||
|             sample = 0.0f; | ||||
|             m_toneNco.setPhase(0); | ||||
|             if (m_cwSmoother.getFadeSample(false, fadeFactor)) | ||||
|             { | ||||
|                 sample = m_toneNco.next() * fadeFactor; | ||||
|             } | ||||
|             else | ||||
|             { | ||||
|                 sample = 0.0f; | ||||
|                 m_toneNco.setPhase(0); | ||||
|             } | ||||
|         } | ||||
|         break; | ||||
|     case NFMModInputNone: | ||||
| @ -366,6 +377,7 @@ void NFMMod::apply() | ||||
|     if (m_config.m_audioSampleRate != m_running.m_audioSampleRate) | ||||
|     { | ||||
|         m_cwKeyer.setSampleRate(m_config.m_audioSampleRate); | ||||
|         m_cwSmoother.setNbFadeSamples(m_config.m_audioSampleRate / 500); // 2 ms
 | ||||
|     } | ||||
| 
 | ||||
| 	m_running.m_outputSampleRate = m_config.m_outputSampleRate; | ||||
|  | ||||
| @ -322,6 +322,7 @@ private: | ||||
|     Real m_peakLevel; | ||||
|     Real m_levelSum; | ||||
|     CWKeyer m_cwKeyer; | ||||
|     CWSmoother m_cwSmoother; | ||||
|     static const int m_levelNbSamples; | ||||
| 
 | ||||
|     void apply(); | ||||
|  | ||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user