mirror of
				https://github.com/f4exb/sdrangel.git
				synced 2025-10-25 10:00:21 -04:00 
			
		
		
		
	FFT filter: SSB filter leave DC component by default in both USB and LSB. Option to remove DC in both
This commit is contained in:
		
							parent
							
								
									13455dfff8
								
							
						
					
					
						commit
						f40d030e2e
					
				| @ -199,7 +199,7 @@ int fftfilt::runFilt(const cmplx & in, cmplx **out) | ||||
| } | ||||
| 
 | ||||
| // Second version for single sideband
 | ||||
| int fftfilt::runSSB(const cmplx & in, cmplx **out, bool usb) | ||||
| int fftfilt::runSSB(const cmplx & in, cmplx **out, bool usb, bool getDC) | ||||
| { | ||||
| 	data[inptr++] = in; | ||||
| 	if (inptr < flen2) | ||||
| @ -208,17 +208,24 @@ int fftfilt::runSSB(const cmplx & in, cmplx **out, bool usb) | ||||
| 
 | ||||
| 	fft->ComplexFFT(data); | ||||
| 
 | ||||
| 	// get or reject DC component
 | ||||
| 	data[0] = getDC ? data[0]*filter[0] : 0; | ||||
| 
 | ||||
| 	// Discard frequencies for ssb
 | ||||
| 	if ( usb ) | ||||
| 		for (int i = 0; i < flen2; i++) { | ||||
| 	if (usb) | ||||
| 	{ | ||||
| 		for (int i = 1; i < flen2; i++) { | ||||
| 			data[i] *= filter[i]; | ||||
| 			data[flen2 + i] = 0; | ||||
| 		} | ||||
| 	} | ||||
| 	else | ||||
| 		for (int i = 0; i < flen2; i++) { | ||||
| 	{ | ||||
| 		for (int i = 1; i < flen2; i++) { | ||||
| 			data[i] = 0; | ||||
| 			data[flen2 + i] *= filter[flen2 + i]; | ||||
| 		} | ||||
| 	} | ||||
| 
 | ||||
| 	// in-place FFT: freqdata overwritten with filtered timedata
 | ||||
| 	fft->InverseComplexFFT(data); | ||||
|  | ||||
| @ -26,7 +26,7 @@ public: | ||||
| 
 | ||||
| 	int noFilt(const cmplx& in, cmplx **out); | ||||
| 	int runFilt(const cmplx& in, cmplx **out); | ||||
| 	int runSSB(const cmplx& in, cmplx **out, bool usb); | ||||
| 	int runSSB(const cmplx& in, cmplx **out, bool usb, bool getDC = true); | ||||
| 	int runDSB(const cmplx& in, cmplx **out); | ||||
| 
 | ||||
| protected: | ||||
|  | ||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user