| 
									
										
										
										
											2023-08-20 21:16:08 +00:00
										 |  |  | /*
 | 
					
						
							|  |  |  |  * Hamlib sample program | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #include <stdio.h>
 | 
					
						
							|  |  |  | #include <string.h>
 | 
					
						
							|  |  |  | #include <unistd.h>
 | 
					
						
							|  |  |  | #include <stdlib.h>
 | 
					
						
							|  |  |  | #include <math.h>
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #include <hamlib/rig.h>
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #include <hamlib/config.h>
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #define HISTORYSIZE 10
 | 
					
						
							|  |  |  | double history[HISTORYSIZE]; | 
					
						
							|  |  |  | int nhistory; | 
					
						
							|  |  |  | int historyinit = 1; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2023-12-16 17:37:58 +00:00
										 |  |  | double compute_mean(const double arr[], int length) | 
					
						
							| 
									
										
										
										
											2023-08-20 21:16:08 +00:00
										 |  |  | { | 
					
						
							|  |  |  |     double sum = 0.0; | 
					
						
							| 
									
										
										
										
											2023-12-16 17:37:58 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  |     for (int i = 0; i < length; i++) | 
					
						
							|  |  |  |     { | 
					
						
							| 
									
										
										
										
											2023-08-20 21:16:08 +00:00
										 |  |  |         sum += arr[i]; | 
					
						
							|  |  |  |     } | 
					
						
							| 
									
										
										
										
											2023-12-16 17:37:58 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2023-08-20 21:16:08 +00:00
										 |  |  |     return sum / length; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2023-12-16 17:37:58 +00:00
										 |  |  | double sigma(double arr[], int length) | 
					
						
							|  |  |  | { | 
					
						
							| 
									
										
										
										
											2023-08-20 21:16:08 +00:00
										 |  |  |     double mean = compute_mean(arr, length); | 
					
						
							|  |  |  |     double sum_of_squares = 0.0; | 
					
						
							| 
									
										
										
										
											2023-12-16 17:37:58 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  |     for (int i = 0; i < length; i++) | 
					
						
							|  |  |  |     { | 
					
						
							| 
									
										
										
										
											2023-08-20 21:16:08 +00:00
										 |  |  |         sum_of_squares += pow(arr[i] - mean, 2); | 
					
						
							|  |  |  |     } | 
					
						
							| 
									
										
										
										
											2023-12-16 17:37:58 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2023-08-20 21:16:08 +00:00
										 |  |  |     return sqrt(sum_of_squares / length); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2023-10-12 04:22:42 +00:00
										 |  |  | int main(int argc, const char *argv[]) | 
					
						
							| 
									
										
										
										
											2023-08-20 21:16:08 +00:00
										 |  |  | { | 
					
						
							|  |  |  |     RIG *my_rig;        /* handle to rig (nstance) */ | 
					
						
							|  |  |  |     int strength;       /* S-Meter level */ | 
					
						
							|  |  |  |     int retcode;        /* generic return code from functions */ | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     rig_model_t myrig_model; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     if (argc != 8) | 
					
						
							|  |  |  |     { | 
					
						
							| 
									
										
										
										
											2023-12-16 17:37:58 +00:00
										 |  |  |         fprintf(stderr, "%s: version 1.0\n", argv[0]); | 
					
						
							|  |  |  |         fprintf(stderr, | 
					
						
							|  |  |  |                 "Usage: %s [model#] [comport] [baud] [start freq] [stop_freq] [stepsize] [seconds/step]\n", | 
					
						
							|  |  |  |                 argv[0]); | 
					
						
							| 
									
										
										
										
											2023-08-20 21:16:08 +00:00
										 |  |  |         return 1; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /* Turn off backend debugging output */ | 
					
						
							|  |  |  |     rig_set_debug_level(RIG_DEBUG_NONE); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /*
 | 
					
						
							|  |  |  |      * allocate memory, setup & open port | 
					
						
							|  |  |  |      */ | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2023-10-12 04:22:42 +00:00
										 |  |  | //    hamlib_port_t myport;
 | 
					
						
							| 
									
										
										
										
											2023-08-20 21:16:08 +00:00
										 |  |  |     myrig_model = atoi(argv[1]); | 
					
						
							| 
									
										
										
										
											2023-10-12 04:22:42 +00:00
										 |  |  | //    strncpy(myport.pathname, argv[2], HAMLIB_FILPATHLEN - 1);
 | 
					
						
							|  |  |  | //    myport.parm.serial.rate = atoi(argv[3]);
 | 
					
						
							| 
									
										
										
										
											2023-08-20 21:16:08 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  |     my_rig = rig_init(myrig_model); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     if (!my_rig) | 
					
						
							|  |  |  |     { | 
					
						
							| 
									
										
										
										
											2023-10-12 04:22:42 +00:00
										 |  |  |         fprintf(stderr, "Unknown rig num: %u\n", myrig_model); | 
					
						
							| 
									
										
										
										
											2023-08-20 21:16:08 +00:00
										 |  |  |         fprintf(stderr, "Please check riglist.h\n"); | 
					
						
							|  |  |  |         exit(1); /* whoops! something went wrong (mem alloc?) */ | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-03-01 01:58:51 +00:00
										 |  |  |     rig_set_conf(my_rig, rig_token_lookup(my_rig, "rig_pathname"), argv[2]); | 
					
						
							| 
									
										
										
										
											2023-08-20 21:16:08 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  |     retcode = rig_open(my_rig); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     if (retcode != RIG_OK) | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         printf("rig_open: error = %s\n", rigerror(retcode)); | 
					
						
							|  |  |  |         exit(2); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | //    printf("Port %s opened ok\n", SERIAL_PORT);
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     long freq1, freq2; | 
					
						
							|  |  |  |     int stepsize, seconds; | 
					
						
							|  |  |  |     int n = sscanf(argv[4], "%ld", &freq1); | 
					
						
							|  |  |  |     n += sscanf(argv[5], "%ld", &freq2); | 
					
						
							|  |  |  |     n += sscanf(argv[6], "%d", &stepsize); | 
					
						
							|  |  |  |     n += sscanf(argv[7], "%d", &seconds); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     if (n != 4) | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         fprintf(stderr, "Error parsing %s/%s/%s/%s as start/stop/step/seconds\n", | 
					
						
							|  |  |  |                 argv[4], argv[5], argv[6], argv[7]); | 
					
						
							|  |  |  |         return 1; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     printf("Start:%ld Stop:%ld Step:%d Wait:%d\n", freq1, freq2, stepsize, seconds); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     while (1) | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         for (long f = freq1; f <= freq2; f += stepsize) | 
					
						
							|  |  |  |         { | 
					
						
							|  |  |  |             retcode = rig_set_freq(my_rig, RIG_VFO_CURR, (freq_t)f); | 
					
						
							| 
									
										
										
										
											2023-12-16 17:37:58 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2023-08-20 21:16:08 +00:00
										 |  |  |             if (retcode != RIG_OK) | 
					
						
							|  |  |  |             { | 
					
						
							|  |  |  |                 fprintf(stderr, "%s: Error rig_set_freq: %s\n", __func__, rigerror(retcode)); | 
					
						
							|  |  |  |                 return 1; | 
					
						
							|  |  |  |             } | 
					
						
							| 
									
										
										
										
											2023-12-16 17:37:58 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2023-08-20 21:16:08 +00:00
										 |  |  |             sleep(seconds); | 
					
						
							|  |  |  |             retcode = rig_get_strength(my_rig, RIG_VFO_CURR, &strength); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |             if (retcode != RIG_OK) | 
					
						
							|  |  |  |             { | 
					
						
							| 
									
										
										
										
											2023-12-16 17:37:58 +00:00
										 |  |  |                 int static  once = 1; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2023-08-20 21:16:08 +00:00
										 |  |  |                 if (once) | 
					
						
							|  |  |  |                 { | 
					
						
							|  |  |  |                     once = 0; | 
					
						
							| 
									
										
										
										
											2023-12-16 17:37:58 +00:00
										 |  |  |                     fprintf(stderr, "rig_get_strength error: %s\n", rigerror(retcode)); | 
					
						
							| 
									
										
										
										
											2023-08-20 21:16:08 +00:00
										 |  |  |                 } | 
					
						
							| 
									
										
										
										
											2023-12-16 17:37:58 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2023-08-20 21:16:08 +00:00
										 |  |  |                 strength = 1; | 
					
						
							|  |  |  |             } | 
					
						
							| 
									
										
										
										
											2023-12-16 17:37:58 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2023-08-20 21:16:08 +00:00
										 |  |  |             history[nhistory++] = strength; | 
					
						
							| 
									
										
										
										
											2023-12-16 17:37:58 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2023-08-20 21:16:08 +00:00
										 |  |  |             if (historyinit) | 
					
						
							|  |  |  |             { | 
					
						
							| 
									
										
										
										
											2023-12-16 17:37:58 +00:00
										 |  |  |                 for (int i = 0; i < HISTORYSIZE; ++i) { history[i] = strength; } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2023-08-20 21:16:08 +00:00
										 |  |  |                 historyinit = 0; | 
					
						
							|  |  |  |             } | 
					
						
							| 
									
										
										
										
											2023-12-16 17:37:58 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2023-08-20 21:16:08 +00:00
										 |  |  |             nhistory %= HISTORYSIZE; | 
					
						
							|  |  |  |             double s = sigma(history, HISTORYSIZE); | 
					
						
							|  |  |  |             char timebuf[64]; | 
					
						
							|  |  |  |             rig_date_strget(timebuf, sizeof(timebuf), 1); | 
					
						
							|  |  |  |             printf("%s\t%ld\t%d\t%f\n", timebuf, f, strength, s); | 
					
						
							|  |  |  |             fflush(stdout); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     rig_close(my_rig); /* close port */ | 
					
						
							|  |  |  |     rig_cleanup(my_rig); /* if you care about memory */ | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     printf("port %s closed ok \n", argv[2]); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     return 0; | 
					
						
							|  |  |  | } |