| 
									
										
										
										
											2014-12-03 00:06:54 +00:00
										 |  |  | #include "astro.h"
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #include <stdio.h>
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #include <QApplication>
 | 
					
						
							|  |  |  | #include <QFile>
 | 
					
						
							|  |  |  | #include <QTextStream>
 | 
					
						
							|  |  |  | #include <QSettings>
 | 
					
						
							|  |  |  | #include <QDateTime>
 | 
					
						
							| 
									
										
										
										
											2018-06-26 00:06:20 +01:00
										 |  |  | #include <QTimeZone>
 | 
					
						
							| 
									
										
										
										
											2014-12-03 00:06:54 +00:00
										 |  |  | #include <QDir>
 | 
					
						
							| 
									
										
										
										
											2017-09-16 10:12:38 +00:00
										 |  |  | #include <QCloseEvent>
 | 
					
						
							| 
									
										
										
										
											2015-04-07 12:08:55 +00:00
										 |  |  | #include <QDebug>
 | 
					
						
							| 
									
										
										
										
											2019-05-22 12:44:28 -04:00
										 |  |  | #include <math.h>
 | 
					
						
							| 
									
										
										
										
											2014-12-03 00:06:54 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | #include "commons.h"
 | 
					
						
							| 
									
										
										
										
											2016-07-03 20:31:19 +00:00
										 |  |  | #include "MessageBox.hpp"
 | 
					
						
							| 
									
										
										
										
											2015-06-11 13:36:13 +00:00
										 |  |  | #include "Configuration.hpp"
 | 
					
						
							|  |  |  | #include "SettingsGroup.hpp"
 | 
					
						
							| 
									
										
										
										
											2015-04-07 12:08:55 +00:00
										 |  |  | #include "qt_helpers.hpp"
 | 
					
						
							| 
									
										
										
										
											2014-12-03 00:06:54 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | #include "ui_astro.h"
 | 
					
						
							|  |  |  | #include "moc_astro.cpp"
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-04-06 17:11:58 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | extern "C" { | 
					
						
							| 
									
										
										
										
											2019-06-06 15:00:47 +01:00
										 |  |  |   void astrosub(int nyear, int month, int nday, double uth, double freqMoon, | 
					
						
							| 
									
										
										
										
											2020-07-20 15:15:55 +01:00
										 |  |  |                 const char * mygrid, const char * hisgrid, | 
					
						
							|  |  |  |                 double * azsun, double * elsun, double * azmoon, | 
					
						
							| 
									
										
										
										
											2019-06-06 15:00:47 +01:00
										 |  |  |                 double * elmoon, double * azmoondx, double * elmoondx, int * ntsky, | 
					
						
							|  |  |  |                 int * ndop, int * ndop00, double * ramoon, double * decmoon, double * dgrd, | 
					
						
							|  |  |  |                 double * poloffset, double * xnr, double * techo, double * width1, | 
					
						
							| 
									
										
										
										
											2020-07-20 15:15:55 +01:00
										 |  |  |                 double * width2, bool bTx, const char * AzElFileName, | 
					
						
							|  |  |  |                 const char * jpleph); | 
					
						
							| 
									
										
										
										
											2016-04-06 17:11:58 +00:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-06-11 13:36:13 +00:00
										 |  |  | Astro::Astro(QSettings * settings, Configuration const * configuration, QWidget * parent) | 
					
						
							| 
									
										
										
										
											2016-04-06 17:11:58 +00:00
										 |  |  |   : QDialog {parent, Qt::WindowTitleHint} | 
					
						
							| 
									
										
										
										
											2014-12-03 00:06:54 +00:00
										 |  |  |   , settings_ {settings} | 
					
						
							| 
									
										
										
										
											2015-06-11 13:36:13 +00:00
										 |  |  |   , configuration_ {configuration} | 
					
						
							| 
									
										
										
										
											2014-12-03 00:06:54 +00:00
										 |  |  |   , ui_ {new Ui::Astro} | 
					
						
							| 
									
										
										
										
											2015-06-11 13:36:13 +00:00
										 |  |  |   , m_DopplerMethod {0} | 
					
						
							| 
									
										
										
										
											2018-02-07 13:43:32 +00:00
										 |  |  |   , m_dop {0} | 
					
						
							|  |  |  |   , m_dop00 {0} | 
					
						
							| 
									
										
										
										
											2020-09-02 21:25:58 +01:00
										 |  |  |   //, m_dx_two_way_dop {0}
 | 
					
						
							| 
									
										
										
										
											2014-12-03 00:06:54 +00:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2015-06-11 13:36:13 +00:00
										 |  |  |   ui_->setupUi (this); | 
					
						
							|  |  |  |   setWindowTitle (QApplication::applicationName () + " - " + tr ("Astronomical Data")); | 
					
						
							| 
									
										
										
										
											2020-06-25 12:57:12 +01:00
										 |  |  |   setBackgroundRole (QPalette::Base); | 
					
						
							|  |  |  |   setAutoFillBackground (true); | 
					
						
							| 
									
										
										
										
											2015-06-11 13:36:13 +00:00
										 |  |  |   connect (ui_->cbDopplerTracking, &QAbstractButton::toggled, ui_->doppler_widget, &QWidget::setVisible); | 
					
						
							| 
									
										
										
										
											2014-12-03 00:06:54 +00:00
										 |  |  |   read_settings (); | 
					
						
							| 
									
										
										
										
											2015-06-11 13:36:13 +00:00
										 |  |  |   ui_->text_label->clear (); | 
					
						
							| 
									
										
										
										
											2014-12-03 00:06:54 +00:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | Astro::~Astro () | 
					
						
							|  |  |  | { | 
					
						
							| 
									
										
										
										
											2016-04-06 17:11:58 +00:00
										 |  |  |   ui_->cbDopplerTracking->setChecked (false); | 
					
						
							|  |  |  |   Q_EMIT tracking_update (); | 
					
						
							| 
									
										
										
										
											2015-04-22 17:48:03 +00:00
										 |  |  |   if (isVisible ()) write_settings (); | 
					
						
							| 
									
										
										
										
											2014-12-03 00:06:54 +00:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | void Astro::closeEvent (QCloseEvent * e) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |   write_settings (); | 
					
						
							| 
									
										
										
										
											2017-09-16 10:12:38 +00:00
										 |  |  |   e->ignore ();                 // do not allow closure by the window system
 | 
					
						
							| 
									
										
										
										
											2014-12-03 00:06:54 +00:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | void Astro::read_settings () | 
					
						
							|  |  |  | { | 
					
						
							| 
									
										
										
										
											2015-06-11 13:36:13 +00:00
										 |  |  |   SettingsGroup g (settings_, "Astro"); | 
					
						
							|  |  |  |   ui_->doppler_widget->setVisible (ui_->cbDopplerTracking->isChecked ()); | 
					
						
							| 
									
										
										
										
											2015-04-22 17:48:03 +00:00
										 |  |  |   m_DopplerMethod=settings_->value("DopplerMethod",0).toInt(); | 
					
						
							| 
									
										
										
										
											2016-04-06 17:11:58 +00:00
										 |  |  |   switch (m_DopplerMethod) | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |     case 0: ui_->rbNoDoppler->setChecked (true); break; | 
					
						
							|  |  |  |     case 1: ui_->rbFullTrack->setChecked (true); break; | 
					
						
							|  |  |  |     case 2: ui_->rbConstFreqOnMoon->setChecked (true); break; | 
					
						
							| 
									
										
										
										
											2018-02-07 13:43:32 +00:00
										 |  |  |     case 3: ui_->rbOwnEcho->setChecked (true); break; | 
					
						
							| 
									
										
										
										
											2020-09-02 21:25:58 +01:00
										 |  |  |     case 4: ui_->rbOnDxEcho->setChecked (true); break; | 
					
						
							|  |  |  |     case 5: ui_->rbCallDx->setChecked (true); break; | 
					
						
							| 
									
										
										
										
											2016-04-06 17:11:58 +00:00
										 |  |  |     } | 
					
						
							| 
									
										
										
										
											2014-12-03 00:06:54 +00:00
										 |  |  |   move (settings_->value ("window/pos", pos ()).toPoint ()); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | void Astro::write_settings () | 
					
						
							|  |  |  | { | 
					
						
							| 
									
										
										
										
											2015-06-11 13:36:13 +00:00
										 |  |  |   SettingsGroup g (settings_, "Astro"); | 
					
						
							| 
									
										
										
										
											2016-04-06 17:11:58 +00:00
										 |  |  |   //settings_->setValue ("DopplerTracking", ui_->cbDopplerTracking->isChecked ());
 | 
					
						
							| 
									
										
										
										
											2015-04-22 17:48:03 +00:00
										 |  |  |   settings_->setValue ("DopplerMethod",m_DopplerMethod); | 
					
						
							| 
									
										
										
										
											2014-12-03 00:06:54 +00:00
										 |  |  |   settings_->setValue ("window/pos", pos ()); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-06-11 13:36:13 +00:00
										 |  |  | auto Astro::astroUpdate(QDateTime const& t, QString const& mygrid, QString const& hisgrid, Frequency freq, | 
					
						
							| 
									
										
										
										
											2019-05-22 12:44:28 -04:00
										 |  |  |                         bool dx_is_self, bool bTx, bool no_tx_QSY, double TR_period) -> Correction | 
					
						
							| 
									
										
										
										
											2014-12-03 00:06:54 +00:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2016-04-06 17:11:58 +00:00
										 |  |  |   Frequency freq_moon {freq}; | 
					
						
							| 
									
										
										
										
											2014-12-03 00:06:54 +00:00
										 |  |  |   double azsun,elsun,azmoon,elmoon,azmoondx,elmoondx; | 
					
						
							| 
									
										
										
										
											2015-05-27 13:08:28 +00:00
										 |  |  |   double ramoon,decmoon,dgrd,poloffset,xnr,techo,width1,width2; | 
					
						
							| 
									
										
										
										
											2015-04-22 17:48:03 +00:00
										 |  |  |   int ntsky; | 
					
						
							| 
									
										
										
										
											2015-06-11 13:36:13 +00:00
										 |  |  |   QString date {t.date().toString("yyyy MMM dd").trimmed ()}; | 
					
						
							|  |  |  |   QString utc {t.time().toString().trimmed ()}; | 
					
						
							|  |  |  |   int nyear {t.date().year()}; | 
					
						
							|  |  |  |   int month {t.date().month()}; | 
					
						
							|  |  |  |   int nday {t.date().day()}; | 
					
						
							|  |  |  |   int nhr {t.time().hour()}; | 
					
						
							|  |  |  |   int nmin {t.time().minute()}; | 
					
						
							|  |  |  |   double sec {t.time().second() + 0.001*t.time().msec()}; | 
					
						
							|  |  |  |   double uth {nhr + nmin/60.0 + sec/3600.0}; | 
					
						
							|  |  |  |   if(freq_moon < 1) freq_moon = 144000000; | 
					
						
							|  |  |  |   auto const& AzElFileName = QDir::toNativeSeparators (configuration_->azel_directory ().absoluteFilePath ("azel.dat")); | 
					
						
							|  |  |  |   auto const& jpleph = configuration_->data_dir ().absoluteFilePath ("JPLEPH"); | 
					
						
							| 
									
										
										
										
											2015-05-27 13:08:28 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-06-06 15:00:47 +01:00
										 |  |  |   astrosub(nyear, month, nday, uth, static_cast<double> (freq_moon), | 
					
						
							| 
									
										
										
										
											2020-07-20 15:15:55 +01:00
										 |  |  |            mygrid.toLatin1 ().data (), | 
					
						
							|  |  |  |            hisgrid.toLatin1().data(), | 
					
						
							| 
									
										
										
										
											2019-06-06 15:00:47 +01:00
										 |  |  |            &azsun, &elsun, &azmoon, &elmoon, | 
					
						
							|  |  |  |            &azmoondx, &elmoondx, &ntsky, &m_dop, &m_dop00, &ramoon, &decmoon, | 
					
						
							|  |  |  |            &dgrd, &poloffset, &xnr, &techo, &width1, &width2, | 
					
						
							|  |  |  |            bTx, | 
					
						
							| 
									
										
										
										
											2020-07-20 15:15:55 +01:00
										 |  |  |            AzElFileName.toLatin1().data(), | 
					
						
							|  |  |  |            jpleph.toLatin1().data()); | 
					
						
							| 
									
										
										
										
											2014-12-03 00:06:54 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-06-06 15:00:47 +01:00
										 |  |  |     if(!hisgrid.size ()) { | 
					
						
							| 
									
										
										
										
											2016-10-14 19:44:01 +00:00
										 |  |  |     azmoondx=0.0; | 
					
						
							|  |  |  |     elmoondx=0.0; | 
					
						
							| 
									
										
										
										
											2018-02-07 13:43:32 +00:00
										 |  |  |     m_dop=0; | 
					
						
							| 
									
										
										
										
											2016-10-14 19:44:01 +00:00
										 |  |  |     width2=0.0; | 
					
						
							|  |  |  |   } | 
					
						
							| 
									
										
										
										
											2014-12-03 00:06:54 +00:00
										 |  |  |   QString message; | 
					
						
							|  |  |  |   { | 
					
						
							|  |  |  |     QTextStream out {&message}; | 
					
						
							| 
									
										
										
										
											2015-06-11 14:38:31 +00:00
										 |  |  |     out << " " << date << "\n" | 
					
						
							| 
									
										
										
										
											2016-10-14 19:44:01 +00:00
										 |  |  |       "UTC:  " << utc << "\n" | 
					
						
							| 
									
										
										
										
											2020-06-13 16:04:41 +01:00
										 |  |  | #if QT_VERSION >= QT_VERSION_CHECK(5, 15, 0)
 | 
					
						
							|  |  |  |         << Qt::fixed | 
					
						
							|  |  |  | #else
 | 
					
						
							| 
									
										
										
										
											2014-12-03 00:06:54 +00:00
										 |  |  |       << fixed | 
					
						
							| 
									
										
										
										
											2020-06-13 16:04:41 +01:00
										 |  |  | #endif
 | 
					
						
							| 
									
										
										
										
											2014-12-03 00:06:54 +00:00
										 |  |  |       << qSetFieldWidth (6) | 
					
						
							|  |  |  |       << qSetRealNumberPrecision (1) | 
					
						
							| 
									
										
										
										
											2015-06-04 19:11:54 +00:00
										 |  |  |       << "Az:     " << azmoon << "\n" | 
					
						
							|  |  |  |       "El:     " << elmoon << "\n" | 
					
						
							| 
									
										
										
										
											2018-02-07 13:43:32 +00:00
										 |  |  |       "SelfDop:" << m_dop00 << "\n" | 
					
						
							| 
									
										
										
										
											2015-06-04 19:11:54 +00:00
										 |  |  |       "Width:  " << int(width1) << "\n" | 
					
						
							| 
									
										
										
										
											2014-12-03 00:06:54 +00:00
										 |  |  |       << qSetRealNumberPrecision (2) | 
					
						
							| 
									
										
										
										
											2015-06-04 19:11:54 +00:00
										 |  |  |       << "Delay:  " << techo << "\n" | 
					
						
							| 
									
										
										
										
											2014-12-03 00:06:54 +00:00
										 |  |  |       << qSetRealNumberPrecision (1) | 
					
						
							| 
									
										
										
										
											2015-06-04 19:11:54 +00:00
										 |  |  |       << "DxAz:   " << azmoondx << "\n" | 
					
						
							|  |  |  |       "DxEl:   " << elmoondx << "\n" | 
					
						
							| 
									
										
										
										
											2018-02-07 13:43:32 +00:00
										 |  |  |       "DxDop:  " << m_dop << "\n" | 
					
						
							| 
									
										
										
										
											2015-06-04 19:11:54 +00:00
										 |  |  |       "DxWid:  " << int(width2) << "\n" | 
					
						
							|  |  |  |       "Dec:    " << decmoon << "\n" | 
					
						
							|  |  |  |       "SunAz:  " << azsun << "\n" | 
					
						
							|  |  |  |       "SunEl:  " << elsun << "\n" | 
					
						
							| 
									
										
										
										
											2019-06-06 15:00:47 +01:00
										 |  |  |       "Freq:   " << freq / 1.e6 << "\n"; | 
					
						
							|  |  |  |     if(freq>=5000000ull) {                     //Suppress data not relevant below VHF
 | 
					
						
							| 
									
										
										
										
											2015-06-11 14:38:31 +00:00
										 |  |  |       out << "Tsky:   " << ntsky << "\n" | 
					
						
							| 
									
										
										
										
											2016-07-04 18:25:10 +00:00
										 |  |  |         "Dpol:   " << poloffset << "\n" | 
					
						
							| 
									
										
										
										
											2020-12-08 00:01:46 +00:00
										 |  |  | 		"MNR:    " << xnr << "\n" | 
					
						
							|  |  |  |         "Dist:   " << int((techo*149896)) << "\n" //wdg
 | 
					
						
							| 
									
										
										
										
											2015-06-11 14:38:31 +00:00
										 |  |  |         "Dgrd:   " << dgrd; | 
					
						
							|  |  |  |     } | 
					
						
							| 
									
										
										
										
											2014-12-03 00:06:54 +00:00
										 |  |  |   } | 
					
						
							|  |  |  |   ui_->text_label->setText(message); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-04-06 17:11:58 +00:00
										 |  |  |   Correction correction; | 
					
						
							| 
									
										
										
										
											2015-06-12 00:26:36 +00:00
										 |  |  |   if (ui_->cbDopplerTracking->isChecked ()) { | 
					
						
							|  |  |  |     switch (m_DopplerMethod) | 
					
						
							|  |  |  |       { | 
					
						
							| 
									
										
										
										
											2016-04-06 17:11:58 +00:00
										 |  |  |       case 1: // All Doppler correction done here; DX station stays at nominal dial frequency.
 | 
					
						
							| 
									
										
										
										
											2020-09-02 21:25:58 +01:00
										 |  |  |         correction.rx =  m_dop; | 
					
						
							|  |  |  |         break; | 
					
						
							|  |  |  |       case 4: // All Doppler correction done here; DX station stays at nominal dial frequency. (Trial for OnDxEcho)
 | 
					
						
							|  |  |  |         correction.rx =  m_dop; | 
					
						
							|  |  |  |         break; | 
					
						
							|  |  |  |         //case 5: // All Doppler correction done here; DX station stays at nominal dial frequency.
 | 
					
						
							| 
									
										
										
										
											2016-04-06 17:11:58 +00:00
										 |  |  |       case 3: // Both stations do full correction on Rx and none on Tx
 | 
					
						
							| 
									
										
										
										
											2018-02-07 13:43:32 +00:00
										 |  |  |         //correction.rx = dx_is_self ? m_dop00 : m_dop;
 | 
					
						
							| 
									
										
										
										
											2020-09-02 21:25:58 +01:00
										 |  |  |         correction.rx =  m_dop00; // Now always sets RX to *own* echo freq
 | 
					
						
							| 
									
										
										
										
											2015-06-12 00:26:36 +00:00
										 |  |  |         break; | 
					
						
							| 
									
										
										
										
											2020-09-02 21:25:58 +01:00
										 |  |  |       case 2: | 
					
						
							| 
									
										
										
										
											2015-06-12 00:26:36 +00:00
										 |  |  |         // Doppler correction to constant frequency on Moon
 | 
					
						
							| 
									
										
										
										
											2018-02-07 13:43:32 +00:00
										 |  |  |         correction.rx = m_dop00 / 2; | 
					
						
							| 
									
										
										
										
											2015-06-12 00:26:36 +00:00
										 |  |  |         break; | 
					
						
							|  |  |  |       } | 
					
						
							| 
									
										
										
										
											2018-02-07 13:43:32 +00:00
										 |  |  |     switch (m_DopplerMethod) | 
					
						
							|  |  |  |       { | 
					
						
							| 
									
										
										
										
											2020-09-02 21:25:58 +01:00
										 |  |  |       case 1: correction.tx = -correction.rx; | 
					
						
							|  |  |  |         break; | 
					
						
							|  |  |  |       case 2: correction.tx = -correction.rx; | 
					
						
							|  |  |  |         break; | 
					
						
							|  |  |  |       case 3: correction.tx = 0; | 
					
						
							|  |  |  |         break; | 
					
						
							|  |  |  |       case 4: // correction.tx = m_dop - m_dop00;
 | 
					
						
							|  |  |  |         correction.tx = (2 * (m_dop - (m_dop00/2))) - m_dop; | 
					
						
							|  |  |  |         //qDebug () << "correction.tx:" << correction.tx;
 | 
					
						
							|  |  |  |         break; | 
					
						
							|  |  |  |       case 5: correction.tx = - m_dop00; | 
					
						
							|  |  |  |         break; | 
					
						
							| 
									
										
										
										
											2018-02-07 13:43:32 +00:00
										 |  |  |       } | 
					
						
							|  |  |  |     //if (3 != m_DopplerMethod || 4 != m_DopplerMethod) correction.tx = -correction.rx;
 | 
					
						
							|  |  |  |      | 
					
						
							| 
									
										
										
										
											2016-04-06 17:11:58 +00:00
										 |  |  |     if(dx_is_self && m_DopplerMethod == 1) correction.rx = 0; | 
					
						
							| 
									
										
										
										
											2015-04-22 17:48:03 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-04-06 17:11:58 +00:00
										 |  |  |     if (no_tx_QSY && 3 != m_DopplerMethod && 0 != m_DopplerMethod) | 
					
						
							|  |  |  |       { | 
					
						
							| 
									
										
										
										
											2018-02-07 13:43:32 +00:00
										 |  |  |        // calculate a single correction for transmit half way through
 | 
					
						
							|  |  |  |        // the period as a compromise for rigs that can't CAT QSY
 | 
					
						
							|  |  |  |        // while transmitting
 | 
					
						
							| 
									
										
										
										
											2016-04-06 17:11:58 +00:00
										 |  |  |         //
 | 
					
						
							|  |  |  |         // use a base time of (secs-since-epoch + 2) so as to be sure
 | 
					
						
							|  |  |  |         // we do the next period if we calculate just before it starts
 | 
					
						
							| 
									
										
										
										
											2019-05-22 12:44:28 -04:00
										 |  |  |         auto sec_since_epoch = t.toMSecsSinceEpoch ()/1000 + 2; | 
					
						
							|  |  |  |         auto target_sec = sec_since_epoch - fmod(double(sec_since_epoch),TR_period) + 0.5*TR_period; | 
					
						
							| 
									
										
										
										
											2018-11-19 21:18:41 -05:00
										 |  |  |         auto target_date_time = QDateTime::fromMSecsSinceEpoch (target_sec * 1000, Qt::UTC); | 
					
						
							| 
									
										
										
										
											2016-04-06 17:11:58 +00:00
										 |  |  |         int nyear {target_date_time.date().year()}; | 
					
						
							|  |  |  |         int month {target_date_time.date().month()}; | 
					
						
							|  |  |  |         int nday {target_date_time.date().day()}; | 
					
						
							|  |  |  |         int nhr {target_date_time.time().hour()}; | 
					
						
							|  |  |  |         int nmin {target_date_time.time().minute()}; | 
					
						
							|  |  |  |         double sec {target_date_time.time().second() + 0.001*target_date_time.time().msec()}; | 
					
						
							|  |  |  |         double uth {nhr + nmin/60.0 + sec/3600.0}; | 
					
						
							| 
									
										
										
										
											2019-06-06 15:00:47 +01:00
										 |  |  |         astrosub(nyear, month, nday, uth, static_cast<double> (freq_moon), | 
					
						
							| 
									
										
										
										
											2020-07-20 15:15:55 +01:00
										 |  |  |                   mygrid.toLatin1 ().data (), | 
					
						
							|  |  |  |                   hisgrid.toLatin1().data(), | 
					
						
							| 
									
										
										
										
											2019-06-06 15:00:47 +01:00
										 |  |  |                   &azsun, &elsun, &azmoon, &elmoon, | 
					
						
							| 
									
										
										
										
											2018-02-07 13:43:32 +00:00
										 |  |  |                   &azmoondx, &elmoondx, &ntsky, &m_dop, &m_dop00, &ramoon, &decmoon, | 
					
						
							| 
									
										
										
										
											2019-06-06 15:00:47 +01:00
										 |  |  |                   &dgrd, &poloffset, &xnr, &techo, &width1, &width2, | 
					
						
							|  |  |  |                   bTx, | 
					
						
							| 
									
										
										
										
											2020-07-20 15:15:55 +01:00
										 |  |  |                   nullptr,      // don't overwrite azel.dat
 | 
					
						
							|  |  |  |                   jpleph.toLatin1().data()); | 
					
						
							| 
									
										
										
										
											2016-04-06 17:11:58 +00:00
										 |  |  |         FrequencyDelta offset {0}; | 
					
						
							|  |  |  |         switch (m_DopplerMethod) | 
					
						
							|  |  |  |           { | 
					
						
							|  |  |  |           case 1: | 
					
						
							|  |  |  |             // All Doppler correction done here; DX station stays at nominal dial frequency.
 | 
					
						
							| 
									
										
										
										
											2018-02-07 13:43:32 +00:00
										 |  |  |             offset = dx_is_self ? m_dop00 : m_dop; | 
					
						
							| 
									
										
										
										
											2016-04-06 17:11:58 +00:00
										 |  |  |             break; | 
					
						
							| 
									
										
										
										
											2015-04-22 17:48:03 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-04-06 17:11:58 +00:00
										 |  |  |           case 2: | 
					
						
							|  |  |  |             // Doppler correction to constant frequency on Moon
 | 
					
						
							| 
									
										
										
										
											2020-09-02 21:25:58 +01:00
										 |  |  |             offset = m_dop00 / 2; | 
					
						
							|  |  |  |             break; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |           case 4: | 
					
						
							| 
									
										
										
										
											2018-02-07 13:43:32 +00:00
										 |  |  |             // Doppler correction for OnDxEcho
 | 
					
						
							| 
									
										
										
										
											2020-09-02 21:25:58 +01:00
										 |  |  |             offset = m_dop - (2 * (m_dop - (m_dop00/2))); | 
					
						
							|  |  |  |             break; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |             //case 5: correction.tx = - m_dop00;
 | 
					
						
							|  |  |  |           case 5: offset = m_dop00;// version for _7
 | 
					
						
							| 
									
										
										
										
											2016-04-06 17:11:58 +00:00
										 |  |  |             break; | 
					
						
							|  |  |  |           } | 
					
						
							|  |  |  |         correction.tx = -offset; | 
					
						
							| 
									
										
										
										
											2020-09-02 21:25:58 +01:00
										 |  |  |         //qDebug () << "correction.tx (no tx qsy):" << correction.tx;
 | 
					
						
							| 
									
										
										
										
											2016-04-06 17:11:58 +00:00
										 |  |  |       } | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  |   return correction; | 
					
						
							| 
									
										
										
										
											2015-04-22 17:48:03 +00:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-04-06 17:11:58 +00:00
										 |  |  | void Astro::check_split () | 
					
						
							| 
									
										
										
										
											2015-04-22 17:48:03 +00:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2016-04-06 17:11:58 +00:00
										 |  |  |   if (doppler_tracking () && !configuration_->split_mode ()) | 
					
						
							|  |  |  |     { | 
					
						
							| 
									
										
										
										
											2016-07-03 20:31:19 +00:00
										 |  |  |       MessageBox::warning_message (this, tr ("Doppler Tracking Error"), | 
					
						
							|  |  |  |                                    tr ("Split operating is required for Doppler tracking"), | 
					
						
							|  |  |  |                                    tr ("Go to \"Menu->File->Settings->Radio\" to enable split operation")); | 
					
						
							| 
									
										
										
										
											2016-04-06 17:11:58 +00:00
										 |  |  |       ui_->rbNoDoppler->click (); | 
					
						
							|  |  |  |     } | 
					
						
							| 
									
										
										
										
											2015-04-22 17:48:03 +00:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-09-26 21:08:43 +01:00
										 |  |  | void Astro::on_rbFullTrack_clicked(bool) | 
					
						
							| 
									
										
										
										
											2015-04-22 17:48:03 +00:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2016-04-06 17:11:58 +00:00
										 |  |  |   m_DopplerMethod = 1; | 
					
						
							|  |  |  |   check_split (); | 
					
						
							|  |  |  |   Q_EMIT tracking_update (); | 
					
						
							| 
									
										
										
										
											2015-04-22 17:48:03 +00:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-09-26 21:08:43 +01:00
										 |  |  | void Astro::on_rbOnDxEcho_clicked(bool) | 
					
						
							| 
									
										
										
										
											2018-02-07 13:43:32 +00:00
										 |  |  | { | 
					
						
							|  |  |  |   m_DopplerMethod = 4; | 
					
						
							|  |  |  |   check_split (); | 
					
						
							| 
									
										
										
										
											2020-09-02 21:25:58 +01:00
										 |  |  |   //if (checked) {
 | 
					
						
							|  |  |  |   //  m_dx_two_way_dop = 2 * (m_dop - (m_dop00/2));
 | 
					
						
							|  |  |  |   //  qDebug () << "Starting Doppler:" << m_dx_two_way_dop;
 | 
					
						
							|  |  |  |   //}
 | 
					
						
							| 
									
										
										
										
											2018-02-07 13:43:32 +00:00
										 |  |  |   Q_EMIT tracking_update (); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-09-26 21:08:43 +01:00
										 |  |  | void Astro::on_rbOwnEcho_clicked(bool) | 
					
						
							| 
									
										
										
										
											2015-04-22 17:48:03 +00:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2016-04-06 17:11:58 +00:00
										 |  |  |   m_DopplerMethod = 3; | 
					
						
							|  |  |  |   check_split (); | 
					
						
							|  |  |  |   Q_EMIT tracking_update (); | 
					
						
							| 
									
										
										
										
											2015-04-22 17:48:03 +00:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-09-26 21:08:43 +01:00
										 |  |  | void Astro::on_rbCallDx_clicked(bool) | 
					
						
							| 
									
										
										
										
											2018-02-07 13:43:32 +00:00
										 |  |  | { | 
					
						
							|  |  |  |   m_DopplerMethod = 5; | 
					
						
							|  |  |  |   check_split (); | 
					
						
							|  |  |  |   Q_EMIT tracking_update (); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-09-26 21:08:43 +01:00
										 |  |  | void Astro::on_rbConstFreqOnMoon_clicked(bool) | 
					
						
							| 
									
										
										
										
											2015-04-22 17:48:03 +00:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2016-04-06 17:11:58 +00:00
										 |  |  |   m_DopplerMethod = 2; | 
					
						
							|  |  |  |   check_split (); | 
					
						
							|  |  |  |   Q_EMIT tracking_update (); | 
					
						
							| 
									
										
										
										
											2015-04-22 17:48:03 +00:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-09-26 21:08:43 +01:00
										 |  |  | void Astro::on_rbNoDoppler_clicked(bool) | 
					
						
							| 
									
										
										
										
											2015-04-22 17:48:03 +00:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2016-04-06 17:11:58 +00:00
										 |  |  |   m_DopplerMethod = 0; | 
					
						
							|  |  |  |   Q_EMIT tracking_update (); | 
					
						
							| 
									
										
										
										
											2015-04-22 17:48:03 +00:00
										 |  |  | } | 
					
						
							| 
									
										
										
										
											2015-05-27 13:08:28 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-04-06 17:11:58 +00:00
										 |  |  | bool Astro::doppler_tracking () const | 
					
						
							| 
									
										
										
										
											2015-05-27 13:08:28 +00:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2016-04-06 17:11:58 +00:00
										 |  |  |   return ui_->cbDopplerTracking->isChecked () && m_DopplerMethod; | 
					
						
							| 
									
										
										
										
											2015-05-27 13:08:28 +00:00
										 |  |  | } | 
					
						
							| 
									
										
										
										
											2015-06-12 00:26:44 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-04-06 17:11:58 +00:00
										 |  |  | void Astro::on_cbDopplerTracking_toggled(bool) | 
					
						
							| 
									
										
										
										
											2015-06-12 00:26:44 +00:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2016-04-06 17:11:58 +00:00
										 |  |  |   check_split (); | 
					
						
							|  |  |  |   Q_EMIT tracking_update (); | 
					
						
							| 
									
										
										
										
											2015-06-12 00:26:44 +00:00
										 |  |  | } | 
					
						
							| 
									
										
										
										
											2015-11-18 01:28:12 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-04-06 17:11:58 +00:00
										 |  |  | void Astro::nominal_frequency (Frequency rx, Frequency tx) | 
					
						
							| 
									
										
										
										
											2015-11-18 01:28:12 +00:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2016-04-06 17:11:58 +00:00
										 |  |  |   ui_->sked_frequency_label->setText (Radio::pretty_frequency_MHz_string (rx)); | 
					
						
							|  |  |  |   ui_->sked_tx_frequency_label->setText (Radio::pretty_frequency_MHz_string (tx)); | 
					
						
							| 
									
										
										
										
											2015-11-18 01:28:12 +00:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-04-06 17:11:58 +00:00
										 |  |  | void Astro::hideEvent (QHideEvent * e) | 
					
						
							| 
									
										
										
										
											2015-11-18 01:28:12 +00:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2016-04-06 17:11:58 +00:00
										 |  |  |   Q_EMIT tracking_update (); | 
					
						
							|  |  |  |   QWidget::hideEvent (e); | 
					
						
							| 
									
										
										
										
											2015-11-18 01:28:12 +00:00
										 |  |  | } |