| 
									
										
										
										
											2015-06-14 15:21:50 +00:00
										 |  |  | /*
 | 
					
						
							|  |  |  |  Functions used by wsprsim | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | #include "wsprsim_utils.h"
 | 
					
						
							|  |  |  | #include "wsprd_utils.h"
 | 
					
						
							|  |  |  | #include "nhash.h"
 | 
					
						
							|  |  |  | #include "fano.h"
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-02-12 01:13:03 +00:00
										 |  |  | static char get_locator_character_code(char ch); | 
					
						
							|  |  |  | static char get_callsign_character_code(char ch); | 
					
						
							|  |  |  | static long unsigned int pack_grid4_power(char const *grid4, int power); | 
					
						
							|  |  |  | static long unsigned int pack_call(char const *callsign); | 
					
						
							|  |  |  | static void pack_prefix(char *callsign, int32_t *n, int32_t *m, int32_t *nadd ); | 
					
						
							|  |  |  | static void interleave(unsigned char *sym); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-06-14 15:21:50 +00:00
										 |  |  | char get_locator_character_code(char ch) { | 
					
						
							|  |  |  |     if( ch >=48 && ch <=57 ) { //0-9
 | 
					
						
							|  |  |  |         return ch-48; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |     if( ch == 32 ) {  //space
 | 
					
						
							|  |  |  |         return 36; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |     if( ch >= 65 && ch <= 82 ) { //A-Z
 | 
					
						
							|  |  |  |         return ch-65; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |     return -1; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | char get_callsign_character_code(char ch) { | 
					
						
							|  |  |  |     if( ch >=48 && ch <=57 ) { //0-9
 | 
					
						
							|  |  |  |         return ch-48; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |     if( ch == 32 ) {  //space
 | 
					
						
							|  |  |  |         return 36; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |     if( ch >= 65 && ch <= 90 ) { //A-Z
 | 
					
						
							|  |  |  |         return ch-55; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |     return -1; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-02-12 01:13:03 +00:00
										 |  |  | long unsigned int pack_grid4_power(char const *grid4, int power) { | 
					
						
							| 
									
										
										
										
											2015-06-14 15:21:50 +00:00
										 |  |  |     long unsigned int m; | 
					
						
							|  |  |  |      | 
					
						
							|  |  |  |     m=(179-10*grid4[0]-grid4[2])*180+10*grid4[1]+grid4[3]; | 
					
						
							|  |  |  |     m=m*128+power+64; | 
					
						
							|  |  |  |     return m; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-02-12 01:13:03 +00:00
										 |  |  | long unsigned int pack_call(char const *callsign) { | 
					
						
							| 
									
										
										
										
											2016-09-16 19:38:18 +00:00
										 |  |  |     unsigned int i; | 
					
						
							| 
									
										
										
										
											2015-06-14 15:21:50 +00:00
										 |  |  |     long unsigned int n; | 
					
						
							| 
									
										
										
										
											2018-02-12 01:13:03 +00:00
										 |  |  |     char call6[6]; | 
					
						
							|  |  |  |     memset(call6,' ',sizeof(call6)); | 
					
						
							| 
									
										
										
										
											2015-06-14 15:21:50 +00:00
										 |  |  |     // callsign is 6 characters in length. Exactly.
 | 
					
						
							| 
									
										
										
										
											2015-11-21 20:23:39 +00:00
										 |  |  |     size_t call_len = strlen(callsign); | 
					
						
							| 
									
										
										
										
											2015-06-14 15:21:50 +00:00
										 |  |  |     if( call_len > 6 ) { | 
					
						
							|  |  |  |         return 0; | 
					
						
							|  |  |  |     } | 
					
						
							| 
									
										
										
										
											2018-02-12 01:13:03 +00:00
										 |  |  |     if( isdigit(callsign[2]) ) { | 
					
						
							| 
									
										
										
										
											2016-09-16 19:38:18 +00:00
										 |  |  |         for (i=0; i<call_len; i++) { | 
					
						
							| 
									
										
										
										
											2018-02-12 01:13:03 +00:00
										 |  |  |             call6[i]=callsign[i]; | 
					
						
							| 
									
										
										
										
											2015-06-14 15:21:50 +00:00
										 |  |  |         } | 
					
						
							| 
									
										
										
										
											2018-02-12 01:13:03 +00:00
										 |  |  |     } else if( isdigit(callsign[1]) ) { | 
					
						
							| 
									
										
										
										
											2016-12-17 06:41:07 +00:00
										 |  |  |         for (i=1; i<call_len+1; i++) { | 
					
						
							| 
									
										
										
										
											2018-02-12 01:13:03 +00:00
										 |  |  |             call6[i]=callsign[i-1]; | 
					
						
							| 
									
										
										
										
											2015-06-14 15:21:50 +00:00
										 |  |  |         } | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |     for (i=0; i<6; i++) { | 
					
						
							|  |  |  |         call6[i]=get_callsign_character_code(call6[i]); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |     n = call6[0]; | 
					
						
							|  |  |  |     n = n*36+call6[1]; | 
					
						
							|  |  |  |     n = n*10+call6[2]; | 
					
						
							|  |  |  |     n = n*27+call6[3]-10; | 
					
						
							|  |  |  |     n = n*27+call6[4]-10; | 
					
						
							|  |  |  |     n = n*27+call6[5]-10; | 
					
						
							|  |  |  |     return n; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | void pack_prefix(char *callsign, int32_t *n, int32_t *m, int32_t *nadd ) { | 
					
						
							| 
									
										
										
										
											2015-11-21 20:23:39 +00:00
										 |  |  |     size_t i; | 
					
						
							| 
									
										
										
										
											2018-02-12 01:13:03 +00:00
										 |  |  |     char * call6 = calloc(7,sizeof (char)); | 
					
						
							| 
									
										
										
										
											2015-11-21 20:23:39 +00:00
										 |  |  |     size_t i1=strcspn(callsign,"/"); | 
					
						
							| 
									
										
										
										
											2015-06-14 15:21:50 +00:00
										 |  |  |      | 
					
						
							|  |  |  |     if( callsign[i1+2] == 0 ) {  | 
					
						
							|  |  |  |         //single char suffix
 | 
					
						
							|  |  |  |         for (i=0; i<i1; i++) { | 
					
						
							|  |  |  |             call6[i]=callsign[i]; | 
					
						
							|  |  |  |         } | 
					
						
							| 
									
										
										
										
											2018-02-12 01:13:03 +00:00
										 |  |  |         call6[i] = '\0'; | 
					
						
							| 
									
										
										
										
											2015-06-14 15:21:50 +00:00
										 |  |  |         *n=pack_call(call6); | 
					
						
							|  |  |  |         *nadd=1; | 
					
						
							|  |  |  |         int nc = callsign[i1+1]; | 
					
						
							|  |  |  |         if( nc >= 48 && nc <= 57 ) { | 
					
						
							|  |  |  |             *m=nc-48; | 
					
						
							|  |  |  |         } else if ( nc >= 65 && nc <= 90 ) { | 
					
						
							|  |  |  |             *m=nc-65+10; | 
					
						
							|  |  |  |         } else { | 
					
						
							|  |  |  |             *m=38; | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |         *m=60000-32768+*m; | 
					
						
							|  |  |  |     } else if( callsign[i1+3]==0 ) { | 
					
						
							|  |  |  |         //two char suffix
 | 
					
						
							|  |  |  |         for (i=0; i<i1; i++) { | 
					
						
							|  |  |  |             call6[i]=callsign[i]; | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |         *n=pack_call(call6); | 
					
						
							|  |  |  |         *nadd=1; | 
					
						
							|  |  |  |         *m=10*(callsign[i1+1]-48)+(callsign[i1+2]-48); | 
					
						
							|  |  |  |         *m=60000 + 26 + *m; | 
					
						
							|  |  |  |     } else { | 
					
						
							| 
									
										
										
										
											2018-02-12 01:13:03 +00:00
										 |  |  |         char const * pfx = strtok (callsign,"/"); | 
					
						
							|  |  |  |         char const * call = strtok(NULL," "); | 
					
						
							|  |  |  |         *n = pack_call (call); | 
					
						
							|  |  |  |         size_t plen=strlen (pfx); | 
					
						
							| 
									
										
										
										
											2015-06-14 15:21:50 +00:00
										 |  |  |         if( plen ==1 ) { | 
					
						
							|  |  |  |             *m=36; | 
					
						
							|  |  |  |             *m=37*(*m)+36; | 
					
						
							|  |  |  |         } else if( plen == 2 ) { | 
					
						
							|  |  |  |             *m=36; | 
					
						
							|  |  |  |         } else { | 
					
						
							|  |  |  |             *m=0; | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |         for (i=0; i<plen; i++) { | 
					
						
							|  |  |  |             int nc = callsign[i]; | 
					
						
							|  |  |  |             if( nc >= 48 && nc <= 57 ) { | 
					
						
							|  |  |  |                 nc=nc-48; | 
					
						
							|  |  |  |             } else if ( nc >= 65 && nc <= 90 ) { | 
					
						
							|  |  |  |                 nc=nc-65+10; | 
					
						
							|  |  |  |             } else { | 
					
						
							|  |  |  |                 nc=36; | 
					
						
							|  |  |  |             } | 
					
						
							|  |  |  |             *m=37*(*m)+nc; | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |         *nadd=0; | 
					
						
							|  |  |  |         if( *m > 32768 ) { | 
					
						
							|  |  |  |             *m=*m-32768; | 
					
						
							|  |  |  |             *nadd=1; | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |     } | 
					
						
							| 
									
										
										
										
											2018-02-12 01:13:03 +00:00
										 |  |  |     free (call6); | 
					
						
							| 
									
										
										
										
											2015-06-14 15:21:50 +00:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | void interleave(unsigned char *sym) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |     unsigned char tmp[162]; | 
					
						
							|  |  |  |     unsigned char p, i, j; | 
					
						
							|  |  |  |      | 
					
						
							|  |  |  |     p=0; | 
					
						
							|  |  |  |     i=0; | 
					
						
							|  |  |  |     while (p<162) { | 
					
						
							|  |  |  |         j=((i * 0x80200802ULL) & 0x0884422110ULL) * 0x0101010101ULL >> 32; | 
					
						
							|  |  |  |         if (j < 162 ) { | 
					
						
							|  |  |  |             tmp[j]=sym[p]; | 
					
						
							|  |  |  |             p=p+1; | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |         i=i+1; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |     for (i=0; i<162; i++) { | 
					
						
							|  |  |  |         sym[i]=tmp[i]; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-02-25 10:48:38 -06:00
										 |  |  | int get_wspr_channel_symbols(char* rawmessage, char* hashtab, char* loctab, unsigned char* symbols) { | 
					
						
							| 
									
										
										
										
											2018-02-11 17:29:38 +00:00
										 |  |  |     int m=0, ntype=0; | 
					
						
							|  |  |  |     long unsigned int n=0; | 
					
						
							| 
									
										
										
										
											2015-06-14 15:21:50 +00:00
										 |  |  |     int i, j, ihash; | 
					
						
							|  |  |  |     unsigned char pr3[162]= | 
					
						
							|  |  |  |     {1,1,0,0,0,0,0,0,1,0,0,0,1,1,1,0,0,0,1,0, | 
					
						
							|  |  |  |         0,1,0,1,1,1,1,0,0,0,0,0,0,0,1,0,0,1,0,1, | 
					
						
							|  |  |  |         0,0,0,0,0,0,1,0,1,1,0,0,1,1,0,1,0,0,0,1, | 
					
						
							|  |  |  |         1,0,1,0,0,0,0,1,1,0,1,0,1,0,1,0,1,0,0,1, | 
					
						
							|  |  |  |         0,0,1,0,1,1,0,0,0,1,1,0,1,0,1,0,0,0,1,0, | 
					
						
							|  |  |  |         0,0,0,0,1,0,0,1,0,0,1,1,1,0,1,1,0,0,1,1, | 
					
						
							|  |  |  |         0,1,0,0,0,1,1,1,0,0,0,0,0,1,0,1,0,0,1,1, | 
					
						
							|  |  |  |         0,0,0,0,0,0,0,1,1,0,1,0,1,1,0,0,0,1,1,0, | 
					
						
							|  |  |  |         0,0}; | 
					
						
							|  |  |  |     int nu[10]={0,-1,1,0,-1,2,1,0,-1,1}; | 
					
						
							|  |  |  |     char *callsign, *grid, *powstr; | 
					
						
							| 
									
										
										
										
											2015-06-14 20:02:03 +00:00
										 |  |  |     char grid4[5], message[23]; | 
					
						
							|  |  |  |      | 
					
						
							|  |  |  |     memset(message,0,sizeof(char)*23); | 
					
						
							|  |  |  |     i=0; | 
					
						
							|  |  |  |     while ( rawmessage[i] != 0 && i<23 ) { | 
					
						
							|  |  |  |         message[i]=rawmessage[i]; | 
					
						
							|  |  |  |         i++; | 
					
						
							|  |  |  |     } | 
					
						
							| 
									
										
										
										
											2015-06-14 15:21:50 +00:00
										 |  |  |      | 
					
						
							| 
									
										
										
										
											2015-11-21 20:23:39 +00:00
										 |  |  |     size_t i1=strcspn(message," "); | 
					
						
							|  |  |  |     size_t i2=strcspn(message,"/"); | 
					
						
							|  |  |  |     size_t i3=strcspn(message,"<"); | 
					
						
							|  |  |  |     size_t i4=strcspn(message,">"); | 
					
						
							|  |  |  |     size_t mlen=strlen(message); | 
					
						
							| 
									
										
										
										
											2015-06-14 15:21:50 +00:00
										 |  |  |      | 
					
						
							|  |  |  |     // Use the presence and/or absence of "<" and "/" to decide what
 | 
					
						
							|  |  |  |     // type of message. No sanity checks! Beware!
 | 
					
						
							|  |  |  |      | 
					
						
							| 
									
										
										
										
											2022-04-22 07:50:03 -05:00
										 |  |  |     if( i1 >= 3 && i1 < 7 && i2 == mlen && i3 == mlen ) { | 
					
						
							| 
									
										
										
										
											2015-06-14 15:21:50 +00:00
										 |  |  |         // Type 1 message: K9AN EN50 33
 | 
					
						
							|  |  |  |         //                 xxnxxxx xxnn nn
 | 
					
						
							| 
									
										
										
										
											2015-06-18 02:24:06 +00:00
										 |  |  |         callsign = strtok(message," "); | 
					
						
							|  |  |  |         grid = strtok(NULL," "); | 
					
						
							|  |  |  |         powstr = strtok(NULL," "); | 
					
						
							| 
									
										
										
										
											2015-06-14 15:21:50 +00:00
										 |  |  |         int power = atoi(powstr); | 
					
						
							|  |  |  |         n = pack_call(callsign); | 
					
						
							|  |  |  |          | 
					
						
							|  |  |  |         for (i=0; i<4; i++) { | 
					
						
							|  |  |  |             grid4[i]=get_locator_character_code(*(grid+i)); | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |         m = pack_grid4_power(grid4,power); | 
					
						
							|  |  |  |          | 
					
						
							|  |  |  |     } else if ( i3 == 0 && i4 < mlen ) { | 
					
						
							|  |  |  |         // Type 3:      <K1ABC> EN50WC 33
 | 
					
						
							|  |  |  |         //          <PJ4/K1ABC> FK52UD 37
 | 
					
						
							|  |  |  |         // send hash instead of callsign to make room for 6 char grid.
 | 
					
						
							|  |  |  |         // if 4-digit locator is specified, 2 spaces are added to the end.
 | 
					
						
							|  |  |  |         callsign=strtok(message,"<> "); | 
					
						
							|  |  |  |         grid=strtok(NULL," "); | 
					
						
							|  |  |  |         powstr=strtok(NULL," "); | 
					
						
							|  |  |  |         int power = atoi(powstr); | 
					
						
							|  |  |  |         if( power < 0 ) power=0; | 
					
						
							|  |  |  |         if( power > 60 ) power=60; | 
					
						
							|  |  |  |         power=power+nu[power%10]; | 
					
						
							|  |  |  |         ntype=-(power+1); | 
					
						
							|  |  |  |         ihash=nhash(callsign,strlen(callsign),(uint32_t)146); | 
					
						
							|  |  |  |         m=128*ihash + ntype + 64; | 
					
						
							|  |  |  |          | 
					
						
							| 
									
										
										
										
											2018-02-11 17:29:38 +00:00
										 |  |  |         char grid6[7]; | 
					
						
							|  |  |  |         memset(grid6,0,sizeof(char)*7); | 
					
						
							| 
									
										
										
										
											2015-06-14 15:21:50 +00:00
										 |  |  |         j=strlen(grid); | 
					
						
							|  |  |  |         for(i=0; i<j-1; i++) { | 
					
						
							|  |  |  |             grid6[i]=grid[i+1]; | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |         grid6[5]=grid[0]; | 
					
						
							| 
									
										
										
										
											2018-02-11 17:29:38 +00:00
										 |  |  |         n = pack_call(grid6); | 
					
						
							| 
									
										
										
										
											2015-06-14 15:21:50 +00:00
										 |  |  |     } else if ( i2 < mlen ) {  // just looks for a right slash
 | 
					
						
							|  |  |  |         // Type 2: PJ4/K1ABC 37
 | 
					
						
							| 
									
										
										
										
											2018-02-12 01:13:03 +00:00
										 |  |  |         callsign = strtok (message," "); | 
					
						
							| 
									
										
										
										
											2018-02-03 16:31:22 +00:00
										 |  |  |         if( i2==0 || i2>strlen(callsign) ) return 0; //guards against pathological case
 | 
					
						
							| 
									
										
										
										
											2018-02-12 01:13:03 +00:00
										 |  |  |         powstr = strtok (NULL," "); | 
					
						
							|  |  |  |         int power = atoi (powstr); | 
					
						
							| 
									
										
										
										
											2015-06-14 15:21:50 +00:00
										 |  |  |         if( power < 0 ) power=0; | 
					
						
							|  |  |  |         if( power > 60 ) power=60; | 
					
						
							|  |  |  |         power=power+nu[power%10]; | 
					
						
							|  |  |  |         int n1, ng, nadd; | 
					
						
							|  |  |  |         pack_prefix(callsign, &n1, &ng, &nadd); | 
					
						
							|  |  |  |         ntype=power + 1 + nadd; | 
					
						
							|  |  |  |         m=128*ng+ntype+64; | 
					
						
							|  |  |  |         n=n1; | 
					
						
							|  |  |  |     } else { | 
					
						
							|  |  |  |         return 0; | 
					
						
							|  |  |  |     } | 
					
						
							| 
									
										
										
										
											2018-02-12 01:13:03 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-06-14 15:21:50 +00:00
										 |  |  |     // pack 50 bits + 31 (0) tail bits into 11 bytes
 | 
					
						
							|  |  |  |     unsigned char it, data[11]; | 
					
						
							|  |  |  |     memset(data,0,sizeof(char)*11); | 
					
						
							|  |  |  |     it=0xFF & (n>>20); | 
					
						
							|  |  |  |     data[0]=it; | 
					
						
							|  |  |  |     it=0xFF & (n>>12); | 
					
						
							|  |  |  |     data[1]=it; | 
					
						
							|  |  |  |     it=0xFF & (n>>4); | 
					
						
							|  |  |  |     data[2]=it; | 
					
						
							|  |  |  |     it= ((n&(0x0F))<<4) + ((m>>18)&(0x0F)); | 
					
						
							|  |  |  |     data[3]=it; | 
					
						
							|  |  |  |     it=0xFF & (m>>10); | 
					
						
							|  |  |  |     data[4]=it; | 
					
						
							|  |  |  |     it=0xFF & (m>>2); | 
					
						
							|  |  |  |     data[5]=it; | 
					
						
							|  |  |  |     it=(m & 0x03)<<6 ; | 
					
						
							|  |  |  |     data[6]=it; | 
					
						
							|  |  |  |     data[7]=0; | 
					
						
							|  |  |  |     data[8]=0; | 
					
						
							|  |  |  |     data[9]=0; | 
					
						
							|  |  |  |     data[10]=0; | 
					
						
							|  |  |  |      | 
					
						
							|  |  |  |     if( printdata ) { | 
					
						
							|  |  |  |         printf("Data is :"); | 
					
						
							|  |  |  |         for (i=0; i<11; i++) { | 
					
						
							|  |  |  |             printf("%02X ",data[i]); | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |         printf("\n"); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |      | 
					
						
							|  |  |  |     // make sure that the 11-byte data vector is unpackable
 | 
					
						
							|  |  |  |     // unpack it with the routine that the decoder will use and display
 | 
					
						
							|  |  |  |     // the result. let the operator decide whether it worked.
 | 
					
						
							|  |  |  |      | 
					
						
							|  |  |  |     char *check_call_loc_pow, *check_callsign; | 
					
						
							|  |  |  |     check_call_loc_pow=malloc(sizeof(char)*23); | 
					
						
							|  |  |  |     check_callsign=malloc(sizeof(char)*13); | 
					
						
							|  |  |  |     signed char check_data[11]; | 
					
						
							|  |  |  |     memcpy(check_data,data,sizeof(char)*11); | 
					
						
							| 
									
										
										
										
											2018-02-12 01:13:03 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-02-25 10:48:38 -06:00
										 |  |  |     unpk_(check_data,hashtab,loctab,check_call_loc_pow,check_callsign); | 
					
						
							| 
									
										
										
										
											2015-06-15 01:34:32 +00:00
										 |  |  | //    printf("Will decode as: %s\n",check_call_loc_pow);
 | 
					
						
							| 
									
										
										
										
											2018-02-12 01:13:03 +00:00
										 |  |  |   | 
					
						
							| 
									
										
										
										
											2016-03-15 11:46:26 +00:00
										 |  |  |     unsigned int nbytes=11; // The message with tail is packed into almost 11 bytes.
 | 
					
						
							|  |  |  |     unsigned char channelbits[nbytes*8*2]; /* 162 rounded up */ | 
					
						
							| 
									
										
										
										
											2018-02-11 17:29:38 +00:00
										 |  |  |     memset(channelbits,0,sizeof(char)*nbytes*8*2); | 
					
						
							| 
									
										
										
										
											2015-06-14 15:21:50 +00:00
										 |  |  |      | 
					
						
							|  |  |  |     encode(channelbits,data,nbytes); | 
					
						
							|  |  |  |      | 
					
						
							|  |  |  |     interleave(channelbits); | 
					
						
							| 
									
										
										
										
											2018-01-07 15:26:43 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-06-14 15:21:50 +00:00
										 |  |  |     for (i=0; i<162; i++) { | 
					
						
							|  |  |  |         symbols[i]=2*channelbits[i]+pr3[i]; | 
					
						
							|  |  |  |     } | 
					
						
							| 
									
										
										
										
											2018-02-11 17:29:38 +00:00
										 |  |  |     free(check_call_loc_pow); | 
					
						
							|  |  |  |     free(check_callsign);  | 
					
						
							| 
									
										
										
										
											2015-06-14 15:21:50 +00:00
										 |  |  |     return 1; | 
					
						
							|  |  |  | } |