Add optional real-time CFOM to QMAP receiving.

This commit is contained in:
Joe Taylor 2023-12-18 15:28:44 -05:00
parent e211bae779
commit 889531fda6
7 changed files with 195 additions and 111 deletions

View File

@ -71,7 +71,8 @@ void Astro::astroUpdate(QDateTime t, QString mygrid, QString hisgrid,
&dgrd, &poloffset, &xnr, 6, 6);
datcom_.ndop00=ndop00; //Send self Doppler to decoder, via datcom
// qDebug() << "aa" << isec << datcom_.fcenter << nfreq << ndop00;
m_ndop00=ndop00;
snprintf(cc, sizeof(cc),
"Az: %6.1f\n"
"El: %6.1f\n"
@ -199,3 +200,7 @@ void Astro::on_cbOnOff_clicked(bool checked)
if(checked) ui->cbAutoCycle->setChecked(false);
}
int Astro::getSelfDop()
{
return m_ndop00;
}

View File

@ -17,6 +17,8 @@ public:
void astroUpdate(QDateTime t, QString mygrid, QString hisgrid,
int fQSO, int nsetftx, int ntxFreq, QString azelDir, double xavg);
void setFontSize(int n);
int getSelfDop();
~Astro ();
private slots:
@ -27,6 +29,8 @@ private:
Ui::Astro *ui;
QString m_settings_filename;
QString m_AzElDir0;
qint32 m_ndop00=0;
};
#endif

View File

@ -5,6 +5,7 @@ set (libq65_FSRCS
astro.f90
astro0.f90
astrosub.f90
cfom.f90
chkstat.f90
dcoord.f90
decode0.f90

30
qmap/libqmap/cfom.f90 Normal file
View File

@ -0,0 +1,30 @@
subroutine cfom(dd,k0,k,ndop0)
parameter(NMAX=60*96000)
real dd(2,NMAX)
complex*16 w,wstep
complex*8 c
real*8 twopi,dphi
logical first
data first/.true./
save
if(first) then
twopi=8.d0*atan(1.d0)
w=1.d0
first=.false.
endif
dop0=0.5*ndop0
dphi=dop0*twopi/96000.0
wstep=cmplx(cos(dphi),sin(dphi))
do j=k0+1,k
w=w*wstep
c=w*cmplx(dd(1,j),dd(2,j))
dd(1,j)=real(c)
dd(2,j)=aimag(c)
enddo
return
end subroutine cfom

View File

@ -327,6 +327,7 @@ void MainWindow::dataSink(int k)
static int nsum=0;
static int ndiskdat;
static int nb;
static int k0=0;
static float px=0.0;
static uchar lstrong[1024];
static float slimit;
@ -344,6 +345,15 @@ void MainWindow::dataSink(int k)
if(m_NB) nb=1;
nfsample=96000;
if(!m_fs96000) nfsample=95238;
if(ui->cbCFOM->isChecked()) {
int ndop00=0;
if(m_astro_window) ndop00=m_astro_window->getSelfDop();
cfom_(datcom_.d4, &k0, &k, &ndop00);
}
k0=k;
symspec_(&k, &ndiskdat, &nb, &m_NBslider, &nfsample,
&px, s, &nkhz, &ihsym, &nzap, &slimit, lstrong);
@ -838,9 +848,11 @@ void MainWindow::decode() //decode()
int nmin=m_path.mid(i0-2,2).toInt();
double uth=nhr + nmin/60.0;
int nfreq=(int)datcom_.fcenter;
int ndop00;
astrosub00_(&nyear, &month, &nday, &uth, &nfreq, m_myGrid.toLatin1(),&ndop00,6);
datcom_.ndop00=ndop00; //Send self Doppler to decoder, via datcom
int ndop00=0;
if(ui->cbCFOM->isChecked()) {
astrosub00_(&nyear, &month, &nday, &uth, &nfreq, m_myGrid.toLatin1(),&ndop00,6);
}
datcom_.ndop00=ndop00; //Send self Doppler (or 0, if using CFOM) to decoder
fname=m_path.mid(i0-11,11);
}
}
@ -981,7 +993,9 @@ void MainWindow::guiUpdate()
ui->labFreq->setText(t1);
if(nsec != m_sec0) { //Once per second
// qDebug() << "AAA" << nsec << m_fAdd;
// qDebug() << "AAA" << nsec;
static int n60z=99;
int n60=nsec%60;
int itest[5];

View File

@ -206,6 +206,9 @@ extern "C" {
const char* mygrid, int* ndop00, int len1);
void q65c_(int* itimer);
void cfom_(float d4[], int* k0, int* k, int* ndop0);
}
#endif // MAINWINDOW_H

View File

@ -40,26 +40,6 @@
<layout class="QFormLayout" name="formLayout">
<item row="1" column="0">
<layout class="QGridLayout" name="gridLayout">
<item row="0" column="3" colspan="2">
<widget class="QPushButton" name="EraseButton">
<property name="minimumSize">
<size>
<width>50</width>
<height>0</height>
</size>
</property>
<property name="text">
<string>&amp;Erase</string>
</property>
</widget>
</item>
<item row="3" column="3">
<widget class="QCheckBox" name="NBcheckBox">
<property name="text">
<string>NB</string>
</property>
</widget>
</item>
<item row="0" column="5">
<widget class="QPushButton" name="DecodeButton">
<property name="minimumSize">
@ -73,18 +53,12 @@
</property>
</widget>
</item>
<item row="1" column="1" rowspan="3">
<widget class="QLabel" name="labUTC">
<property name="minimumSize">
<size>
<width>140</width>
<height>0</height>
</size>
</property>
<item row="0" column="1">
<widget class="QLabel" name="labFreq">
<property name="maximumSize">
<size>
<width>165</width>
<height>60</height>
<width>16777215</width>
<height>35</height>
</size>
</property>
<property name="font">
@ -96,14 +70,44 @@
<enum>QFrame::Panel</enum>
</property>
<property name="text">
<string> 2023 Feb 02
01:23:45 </string>
<string>1296.080</string>
</property>
<property name="alignment">
<set>Qt::AlignCenter</set>
</property>
</widget>
</item>
<item row="3" column="4" colspan="2">
<widget class="QSlider" name="NBslider">
<property name="enabled">
<bool>false</bool>
</property>
<property name="sizePolicy">
<sizepolicy hsizetype="Fixed" vsizetype="Fixed">
<horstretch>0</horstretch>
<verstretch>0</verstretch>
</sizepolicy>
</property>
<property name="maximumSize">
<size>
<width>80</width>
<height>16777215</height>
</size>
</property>
<property name="minimum">
<number>0</number>
</property>
<property name="maximum">
<number>100</number>
</property>
<property name="value">
<number>40</number>
</property>
<property name="orientation">
<enum>Qt::Horizontal</enum>
</property>
</widget>
</item>
<item row="1" column="2" colspan="2">
<layout class="QHBoxLayout" name="horizontalLayout">
<item>
@ -189,28 +193,45 @@
</item>
</layout>
</item>
<item row="0" column="1">
<widget class="QLabel" name="labFreq">
<property name="maximumSize">
<size>
<width>16777215</width>
<height>35</height>
</size>
</property>
<property name="font">
<font>
<pointsize>16</pointsize>
</font>
</property>
<property name="frameShape">
<enum>QFrame::Panel</enum>
</property>
<property name="text">
<string>1296.080</string>
<item row="2" column="4" colspan="2">
<widget class="QSpinBox" name="sbOffset">
<property name="toolTip">
<string>&lt;html&gt;&lt;head/&gt;&lt;body&gt;&lt;p&gt;Select offset announced by calling station, or use commonly used value for the band in use. Manually set WSJT-X TX and RX offset to same value.&lt;/p&gt;&lt;/body&gt;&lt;/html&gt;</string>
</property>
<property name="alignment">
<set>Qt::AlignCenter</set>
</property>
<property name="suffix">
<string> Hz</string>
</property>
<property name="prefix">
<string>Offset </string>
</property>
<property name="minimum">
<number>500</number>
</property>
<property name="maximum">
<number>2000</number>
</property>
<property name="singleStep">
<number>100</number>
</property>
<property name="value">
<number>1500</number>
</property>
</widget>
</item>
<item row="0" column="3" colspan="2">
<widget class="QPushButton" name="EraseButton">
<property name="minimumSize">
<size>
<width>50</width>
<height>0</height>
</size>
</property>
<property name="text">
<string>&amp;Erase</string>
</property>
</widget>
</item>
<item row="0" column="0" rowspan="4">
@ -229,6 +250,37 @@
</property>
</widget>
</item>
<item row="1" column="1" rowspan="3">
<widget class="QLabel" name="labUTC">
<property name="minimumSize">
<size>
<width>140</width>
<height>0</height>
</size>
</property>
<property name="maximumSize">
<size>
<width>165</width>
<height>60</height>
</size>
</property>
<property name="font">
<font>
<pointsize>16</pointsize>
</font>
</property>
<property name="frameShape">
<enum>QFrame::Panel</enum>
</property>
<property name="text">
<string> 2023 Feb 02
01:23:45 </string>
</property>
<property name="alignment">
<set>Qt::AlignCenter</set>
</property>
</widget>
</item>
<item row="0" column="2">
<widget class="QPushButton" name="monitorButton">
<property name="sizePolicy">
@ -254,34 +306,10 @@
</property>
</widget>
</item>
<item row="3" column="4" colspan="2">
<widget class="QSlider" name="NBslider">
<property name="enabled">
<bool>false</bool>
</property>
<property name="sizePolicy">
<sizepolicy hsizetype="Fixed" vsizetype="Fixed">
<horstretch>0</horstretch>
<verstretch>0</verstretch>
</sizepolicy>
</property>
<property name="maximumSize">
<size>
<width>80</width>
<height>16777215</height>
</size>
</property>
<property name="minimum">
<number>0</number>
</property>
<property name="maximum">
<number>100</number>
</property>
<property name="value">
<number>40</number>
</property>
<property name="orientation">
<enum>Qt::Horizontal</enum>
<item row="3" column="3">
<widget class="QCheckBox" name="NBcheckBox">
<property name="text">
<string>NB</string>
</property>
</widget>
</item>
@ -304,33 +332,32 @@
</property>
</widget>
</item>
<item row="2" column="4" colspan="2">
<widget class="QSpinBox" name="sbOffset">
<property name="toolTip">
<string>&lt;html&gt;&lt;head/&gt;&lt;body&gt;&lt;p&gt;Select offset announced by calling station, or use commonly used value for the band in use. Manually set WSJT-X TX and RX offset to same value.&lt;/p&gt;&lt;/body&gt;&lt;/html&gt;</string>
</property>
<property name="alignment">
<set>Qt::AlignCenter</set>
</property>
<property name="suffix">
<string> Hz</string>
</property>
<property name="prefix">
<string>Offset </string>
</property>
<property name="minimum">
<number>500</number>
</property>
<property name="maximum">
<number>2000</number>
</property>
<property name="singleStep">
<number>100</number>
</property>
<property name="value">
<number>1500</number>
</property>
</widget>
<item row="2" column="2" colspan="2">
<layout class="QHBoxLayout" name="horizontalLayout_2">
<item>
<spacer name="horizontalSpacer">
<property name="orientation">
<enum>Qt::Horizontal</enum>
</property>
<property name="sizeType">
<enum>QSizePolicy::Fixed</enum>
</property>
<property name="sizeHint" stdset="0">
<size>
<width>20</width>
<height>20</height>
</size>
</property>
</spacer>
</item>
<item>
<widget class="QCheckBox" name="cbCFOM">
<property name="text">
<string>Apply CFOM</string>
</property>
</widget>
</item>
</layout>
</item>
</layout>
</item>
@ -421,7 +448,7 @@ p, li { white-space: pre-wrap; }
<x>0</x>
<y>0</y>
<width>640</width>
<height>22</height>
<height>21</height>
</rect>
</property>
<widget class="QMenu" name="menuFile">