mirror of
				https://github.com/f4exb/sdrangel.git
				synced 2025-10-26 02:20:26 -04:00 
			
		
		
		
	
		
			
	
	
		
			157 lines
		
	
	
		
			4.0 KiB
		
	
	
	
		
			C++
		
	
	
	
	
	
		
		
			
		
	
	
			157 lines
		
	
	
		
			4.0 KiB
		
	
	
	
		
			C++
		
	
	
	
	
	
|  | #include "memory.h"
 | ||
|  | #include "DVBS2.h"
 | ||
|  | 
 | ||
|  | //
 | ||
|  | // called at the end of a frame
 | ||
|  | //
 | ||
|  | void  DVBS2::end_of_frame_actions(void) | ||
|  | { | ||
|  |     if( m_s2_config_updated ) | ||
|  |     { | ||
|  |         modulator_configuration(); | ||
|  |         m_s2_config_updated = 0; | ||
|  |     } | ||
|  | } | ||
|  | 
 | ||
|  | int DVBS2::is_valid( int mod, int coderate ) | ||
|  | { | ||
|  |     if( mod == M_QPSK ) | ||
|  |     { | ||
|  |         if(coderate == CR_1_4)  return 0; | ||
|  |         if(coderate == CR_1_3)  return 0; | ||
|  |         if(coderate == CR_2_5)  return 0; | ||
|  |         if(coderate == CR_1_2)  return 0; | ||
|  |         if(coderate == CR_3_5)  return 0; | ||
|  |         if(coderate == CR_2_3)  return 0; | ||
|  |         if(coderate == CR_3_4)  return 0; | ||
|  |         if(coderate == CR_4_5)  return 0; | ||
|  |         if(coderate == CR_5_6)  return 0; | ||
|  |         if(coderate == CR_8_9)  return 0; | ||
|  |         if(coderate == CR_9_10) return 0; | ||
|  |     } | ||
|  |     if( mod == M_8PSK ) | ||
|  |     { | ||
|  |         if(coderate == CR_3_5)  return 0; | ||
|  |         if(coderate == CR_2_3)  return 0; | ||
|  |         if(coderate == CR_3_4)  return 0; | ||
|  |         if(coderate == CR_5_6)  return 0; | ||
|  |         if(coderate == CR_8_9)  return 0; | ||
|  |         if(coderate == CR_9_10) return 0; | ||
|  |     } | ||
|  |     if( mod == M_16APSK ) | ||
|  |     { | ||
|  |         if(coderate == CR_2_3)  return 0; | ||
|  |         if(coderate == CR_3_4)  return 0; | ||
|  |         if(coderate == CR_4_5)  return 0; | ||
|  |         if(coderate == CR_5_6)  return 0; | ||
|  |         if(coderate == CR_8_9)  return 0; | ||
|  |         if(coderate == CR_9_10) return 0; | ||
|  |     } | ||
|  |     if( mod == M_32APSK ) | ||
|  |     { | ||
|  |         if(coderate == CR_3_4)  return 0; | ||
|  |         if(coderate == CR_4_5)  return 0; | ||
|  |         if(coderate == CR_5_6)  return 0; | ||
|  |         if(coderate == CR_8_9)  return 0; | ||
|  |         if(coderate == CR_9_10) return 0; | ||
|  |     } | ||
|  |     return -1; | ||
|  | } | ||
|  | //
 | ||
|  | // index 0 and 1 will only be different when being reconfigured.
 | ||
|  | // Use index 1 as this will be applied in the following transmit
 | ||
|  | // frames
 | ||
|  | //
 | ||
|  | void DVBS2::calc_efficiency( void ) | ||
|  | { | ||
|  |     double p,m,a,s,b,po; | ||
|  |     // Calculate the number of symbols in the payload
 | ||
|  |     p = 0;a = 0; m = 0; | ||
|  |     if( m_format[1].frame_type == FRAME_NORMAL )  p = (double)FRAME_SIZE_NORMAL; | ||
|  |     if( m_format[1].frame_type == FRAME_SHORT  )  p = (double)FRAME_SIZE_SHORT; | ||
|  |     if( m_format[1].constellation == M_QPSK )     m = 2.0; | ||
|  |     if( m_format[1].constellation == M_8PSK )     m = 3.0; | ||
|  |     if( m_format[1].constellation == M_16APSK )   m = 4.0; | ||
|  |     if( m_format[1].constellation == M_32APSK )   m = 5.0; | ||
|  |     s = p/m;//Number of symbols per frame
 | ||
|  |     // PL header overhead
 | ||
|  |     if( m_format[1].pilots ) | ||
|  |     { | ||
|  |         po = (s/(90*16))-1;// 1 pilot every 16 blocks (of 90 symbols)
 | ||
|  |         po = po*36;        // No pilot at the end
 | ||
|  |         a  = s/(90+po+s); | ||
|  |     } | ||
|  |     else | ||
|  |     { | ||
|  |         a = s/(90+s);// No pilots
 | ||
|  |     } | ||
|  |     // Modulation efficiency
 | ||
|  |     a = a*m; | ||
|  |     // Take into account pilot symbols
 | ||
|  |     // TBD
 | ||
|  |     // Now calculate the useable data as percentage of the frame
 | ||
|  |     b = ((double)m_format[1].useable_data_bits)/p; | ||
|  |     // Now calculate the efficiency by multiplying the
 | ||
|  |     // useable bits efficiency by the modulation efficiency
 | ||
|  |     m_efficiency = b*a; | ||
|  | } | ||
|  | //
 | ||
|  | // Multiply the efficiency value by the symbol rate
 | ||
|  | // to get the useable bitrate
 | ||
|  | //
 | ||
|  | double DVBS2::s2_get_efficiency( void ) | ||
|  | { | ||
|  |     return m_efficiency; | ||
|  | } | ||
|  | 
 | ||
|  | int DVBS2::s2_set_configure( DVB2FrameFormat *f ) | ||
|  | { | ||
|  |     if( is_valid( f->constellation, f->code_rate ) == 0 ) | ||
|  |     { | ||
|  |         if( set_configure( f ) == 0 ) | ||
|  |         { | ||
|  |              calc_efficiency(); | ||
|  |              m_s2_config_updated = 1; | ||
|  | 			 m_configured = 1; | ||
|  | 
 | ||
|  |              return 0; | ||
|  |         } | ||
|  |     } | ||
|  |     return -1; | ||
|  | } | ||
|  | void DVBS2::s2_get_configure( DVB2FrameFormat *f ) | ||
|  | { | ||
|  |     get_configure( f ); | ||
|  | } | ||
|  | int DVBS2::s2_add_ts_frame( u8 *ts ) | ||
|  | { | ||
|  |     int res = 0; | ||
|  | 	if (m_configured == 0) return 0; | ||
|  |     // Call base class
 | ||
|  |     if( next_ts_frame_base( ts ) ) | ||
|  |     { | ||
|  |         // Interleave and pack
 | ||
|  |         s2_interleave(); | ||
|  |         // create the header
 | ||
|  |         s2_pl_header_create(); | ||
|  |         // Add the data
 | ||
|  |         res = s2_pl_data_pack(); | ||
|  |         // Do any updates required for the next frame
 | ||
|  |         end_of_frame_actions(); | ||
|  |     } | ||
|  |     return res; | ||
|  | } | ||
|  | void DVBS2::physical( void ) | ||
|  | { | ||
|  | 
 | ||
|  | } | ||
|  | 
 | ||
|  | DVBS2::DVBS2() | ||
|  | { | ||
|  | 	m_configured = 0; | ||
|  |     modulator_configuration(); | ||
|  |     build_symbol_scrambler_table(); | ||
|  |     pl_build_dummy(); | ||
|  | } | ||
|  | 
 |