mirror of
https://github.com/saitohirga/WSJT-X.git
synced 2024-11-26 06:08:42 -05:00
Further progress toward a usable "FreqCal" (Frequency Calibration) mode.
git-svn-id: svn+ssh://svn.code.sf.net/p/wsjt/wsjt/branches/wsjtx@7448 ab8295b8-cf94-4d9e-aec4-7959e3be5d79
This commit is contained in:
parent
838555c08c
commit
6d3ca346e0
@ -363,6 +363,7 @@ set (wsjt_FSRCS
|
|||||||
lib/foldspec9f.f90
|
lib/foldspec9f.f90
|
||||||
lib/four2a.f90
|
lib/four2a.f90
|
||||||
lib/fqso_first.f90
|
lib/fqso_first.f90
|
||||||
|
lib/freqcal.f90
|
||||||
lib/gen4.f90
|
lib/gen4.f90
|
||||||
lib/gen65.f90
|
lib/gen65.f90
|
||||||
lib/gen9.f90
|
lib/gen9.f90
|
||||||
|
51
lib/freqcal.f90
Normal file
51
lib/freqcal.f90
Normal file
@ -0,0 +1,51 @@
|
|||||||
|
subroutine freqcal(id2,k,nfreq,ntol,line)
|
||||||
|
|
||||||
|
parameter (NZ=30*12000,NFFT=55296,NH=NFFT/2)
|
||||||
|
integer*2 id2(0:NZ-1)
|
||||||
|
real x(0:NFFT-1)
|
||||||
|
real s(NH)
|
||||||
|
character line*27
|
||||||
|
complex cx(0:NH)
|
||||||
|
equivalence (x,cx)
|
||||||
|
data n/0/,k0/9999999/
|
||||||
|
save n,k0
|
||||||
|
|
||||||
|
if(k.lt.k0) n=0
|
||||||
|
k0=k
|
||||||
|
|
||||||
|
x=0.001*id2(k-NFFT:k-1)
|
||||||
|
call four2a(x,NFFT,1,-1,0) !Compute spectrum, r2c
|
||||||
|
df=12000.0/NFFT
|
||||||
|
ia=nint((nfreq-ntol)/df)
|
||||||
|
ib=nint((nfreq+ntol)/df)
|
||||||
|
smax=0.
|
||||||
|
s=0.
|
||||||
|
do i=ia,ib
|
||||||
|
s(i)=real(cx(i))**2 + aimag(cx(i))**2
|
||||||
|
if(s(i).gt.smax) then
|
||||||
|
smax=s(i)
|
||||||
|
ipk=i
|
||||||
|
endif
|
||||||
|
enddo
|
||||||
|
|
||||||
|
call peakup(s(ipk-1),s(ipk),s(ipk+1),dx)
|
||||||
|
fpeak=df * (ipk+dx)
|
||||||
|
sum=0.
|
||||||
|
nsum=0
|
||||||
|
do i=ia,ib
|
||||||
|
if(abs(i-ipk).gt.10) then
|
||||||
|
sum=sum+s(i)
|
||||||
|
nsum=nsum+1
|
||||||
|
endif
|
||||||
|
enddo
|
||||||
|
ave=sum/nsum
|
||||||
|
pave=db(ave) + 8.0
|
||||||
|
snr=db(smax/ave)
|
||||||
|
! if(snr.lt.20.0) cflag='*'
|
||||||
|
n=n+1
|
||||||
|
write(line,1100) fpeak,snr
|
||||||
|
1100 format(2f8.1)
|
||||||
|
line(27:27)=char(0)
|
||||||
|
|
||||||
|
return
|
||||||
|
end subroutine freqcal
|
@ -102,6 +102,7 @@ extern "C" {
|
|||||||
int ptt_(int nport, int ntx, int* iptt, int* nopen);
|
int ptt_(int nport, int ntx, int* iptt, int* nopen);
|
||||||
|
|
||||||
void wspr_downsample_(short int d2[], int* k);
|
void wspr_downsample_(short int d2[], int* k);
|
||||||
|
|
||||||
int savec2_(char* fname, int* TR_seconds, double* dial_freq, int len1);
|
int savec2_(char* fname, int* TR_seconds, double* dial_freq, int len1);
|
||||||
|
|
||||||
void avecho_( short id2[], int* dop, int* nfrit, int* nqual, float* f1,
|
void avecho_( short id2[], int* dop, int* nfrit, int* nqual, float* f1,
|
||||||
@ -112,9 +113,13 @@ extern "C" {
|
|||||||
char msg[], char mycall[], char hiscall[],
|
char msg[], char mycall[], char hiscall[],
|
||||||
int len1, int len2, int len3);
|
int len1, int len2, int len3);
|
||||||
void degrade_snr_(short d2[], int* n, float* db, float* bandwidth);
|
void degrade_snr_(short d2[], int* n, float* db, float* bandwidth);
|
||||||
|
|
||||||
void wav12_(short d2[], short d1[], int* nbytes, short* nbitsam2);
|
void wav12_(short d2[], short d1[], int* nbytes, short* nbitsam2);
|
||||||
|
|
||||||
void refspectrum_(short int d2[], bool* bclearrefspec, bool* brefspec,
|
void refspectrum_(short int d2[], bool* bclearrefspec, bool* brefspec,
|
||||||
bool* buseref, const char* c_fname, int len);
|
bool* buseref, const char* c_fname, int len);
|
||||||
|
|
||||||
|
void freqcal_(short d2[], int* k, int* nfreq, int* ntol, char line[], int len);
|
||||||
}
|
}
|
||||||
|
|
||||||
int volatile itone[NUM_ISCAT_SYMBOLS]; //Audio tones for all Tx symbols
|
int volatile itone[NUM_ISCAT_SYMBOLS]; //Audio tones for all Tx symbols
|
||||||
@ -1090,6 +1095,7 @@ void MainWindow::fixStop()
|
|||||||
void MainWindow::dataSink(qint64 frames)
|
void MainWindow::dataSink(qint64 frames)
|
||||||
{
|
{
|
||||||
static float s[NSMAX];
|
static float s[NSMAX];
|
||||||
|
char line[27];
|
||||||
|
|
||||||
int k (frames);
|
int k (frames);
|
||||||
QString fname {QDir::toNativeSeparators(m_dataDir.absoluteFilePath ("refspec.dat"))};
|
QString fname {QDir::toNativeSeparators(m_dataDir.absoluteFilePath ("refspec.dat"))};
|
||||||
@ -1133,6 +1139,18 @@ void MainWindow::dataSink(qint64 frames)
|
|||||||
}
|
}
|
||||||
|
|
||||||
fixStop();
|
fixStop();
|
||||||
|
if(m_mode=="FreqCal" and m_ihsym>=16 and m_ihsym%8==0) {
|
||||||
|
m_RxFreq=ui->RxFreqSpinBox->value ();
|
||||||
|
freqcal_(&dec_data.d2[0],&k,&m_RxFreq,&m_Ftol,&line[0],27);
|
||||||
|
QString t=QString::fromLatin1(line);
|
||||||
|
|
||||||
|
DecodedText decodedtext;
|
||||||
|
decodedtext=t;
|
||||||
|
ui->decodedTextBrowser->displayDecodedText (decodedtext,m_baseCall,m_config.DXCC(),
|
||||||
|
m_logBook,m_config.color_CQ(),m_config.color_MyCall(),m_config.color_DXCC(),
|
||||||
|
m_config.color_NewCall());
|
||||||
|
}
|
||||||
|
|
||||||
if(m_ihsym==3*m_hsymStop/4) {
|
if(m_ihsym==3*m_hsymStop/4) {
|
||||||
m_dialFreqRxWSPR=m_freqNominal;
|
m_dialFreqRxWSPR=m_freqNominal;
|
||||||
}
|
}
|
||||||
@ -1166,7 +1184,6 @@ void MainWindow::dataSink(qint64 frames)
|
|||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
if(m_mode=="FreqCal") {
|
if(m_mode=="FreqCal") {
|
||||||
qDebug() << "A" << m_ihsym;
|
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
if( m_dialFreqRxWSPR==0) m_dialFreqRxWSPR=m_freqNominal;
|
if( m_dialFreqRxWSPR==0) m_dialFreqRxWSPR=m_freqNominal;
|
||||||
@ -1971,12 +1988,14 @@ void MainWindow::on_actionHide_Controls_triggered()
|
|||||||
minimumSize().setWidth(770);
|
minimumSize().setWidth(770);
|
||||||
}
|
}
|
||||||
ui->menuBar->setVisible(!m_bHideControls);
|
ui->menuBar->setVisible(!m_bHideControls);
|
||||||
|
if(m_mode!="FreqCal") {
|
||||||
ui->label_6->setVisible(!m_bHideControls);
|
ui->label_6->setVisible(!m_bHideControls);
|
||||||
ui->line->setVisible(!m_bHideControls);
|
|
||||||
ui->line_2->setVisible(!m_bHideControls);
|
|
||||||
ui->label_7->setVisible(!m_bHideControls);
|
ui->label_7->setVisible(!m_bHideControls);
|
||||||
ui->decodedTextLabel->setVisible(!m_bHideControls);
|
|
||||||
ui->decodedTextLabel2->setVisible(!m_bHideControls);
|
ui->decodedTextLabel2->setVisible(!m_bHideControls);
|
||||||
|
ui->line_2->setVisible(!m_bHideControls);
|
||||||
|
}
|
||||||
|
ui->line->setVisible(!m_bHideControls);
|
||||||
|
ui->decodedTextLabel->setVisible(!m_bHideControls);
|
||||||
ui->gridLayout_5->layout()->setSpacing(spacing);
|
ui->gridLayout_5->layout()->setSpacing(spacing);
|
||||||
ui->horizontalLayout->layout()->setSpacing(spacing);
|
ui->horizontalLayout->layout()->setSpacing(spacing);
|
||||||
ui->horizontalLayout_2->layout()->setSpacing(spacing);
|
ui->horizontalLayout_2->layout()->setSpacing(spacing);
|
||||||
@ -4508,14 +4527,13 @@ void MainWindow::on_actionEcho_triggered()
|
|||||||
|
|
||||||
void MainWindow::on_actionFreqCal_triggered()
|
void MainWindow::on_actionFreqCal_triggered()
|
||||||
{
|
{
|
||||||
on_actionEcho_triggered();
|
on_actionJT9_triggered();
|
||||||
if(m_echoGraph->isVisible()) m_echoGraph->hide();
|
displayWidgets(nWidgets("001100000000000000000000"));
|
||||||
if(ui->actionAstronomical_data->isChecked()) {
|
|
||||||
ui->actionAstronomical_data->setChecked (false);
|
|
||||||
}
|
|
||||||
m_mode="FreqCal";
|
m_mode="FreqCal";
|
||||||
displayWidgets(nWidgets("000000000000000000000000"));
|
|
||||||
ui->actionFreqCal->setChecked(true);
|
ui->actionFreqCal->setChecked(true);
|
||||||
|
switch_mode(Modes::FreqCal);
|
||||||
|
m_wideGraph->setMode(m_mode);
|
||||||
|
statusChanged();
|
||||||
m_TRperiod=30;
|
m_TRperiod=30;
|
||||||
m_modulator->setPeriod(m_TRperiod); // TODO - not thread safe
|
m_modulator->setPeriod(m_TRperiod); // TODO - not thread safe
|
||||||
m_detector->setPeriod(m_TRperiod); // TODO - not thread safe
|
m_detector->setPeriod(m_TRperiod); // TODO - not thread safe
|
||||||
@ -4523,15 +4541,8 @@ void MainWindow::on_actionFreqCal_triggered()
|
|||||||
m_FFTSize = m_nsps / 2;
|
m_FFTSize = m_nsps / 2;
|
||||||
Q_EMIT FFTSize (m_FFTSize);
|
Q_EMIT FFTSize (m_FFTSize);
|
||||||
m_hsymStop=100;
|
m_hsymStop=100;
|
||||||
switch_mode(Modes::FreqCal);
|
|
||||||
setup_status_bar (true);
|
setup_status_bar (true);
|
||||||
m_wideGraph->setMode(m_mode);
|
ui->decodedTextLabel->setText(" Freq S/N");
|
||||||
m_bFastMode=true;
|
|
||||||
m_bFast9=false;
|
|
||||||
fast_config(false);
|
|
||||||
// WSPR_config(true);
|
|
||||||
ui->decodedTextLabel->setText(" UTC N Level Sig DF Width Q");
|
|
||||||
statusChanged();
|
|
||||||
}
|
}
|
||||||
|
|
||||||
void MainWindow::switch_mode (Mode mode)
|
void MainWindow::switch_mode (Mode mode)
|
||||||
@ -4558,6 +4569,15 @@ void MainWindow::switch_mode (Mode mode)
|
|||||||
ui->RxFreqSpinBox->setSingleStep(1);
|
ui->RxFreqSpinBox->setSingleStep(1);
|
||||||
}
|
}
|
||||||
m_bVHFwarned=false;
|
m_bVHFwarned=false;
|
||||||
|
bool b=m_mode=="FreqCal";
|
||||||
|
ui->tabWidget->setVisible(!b);
|
||||||
|
if(b) {
|
||||||
|
ui->DX_controls_widget->setVisible(false);
|
||||||
|
ui->decodedTextBrowser2->setVisible(false);
|
||||||
|
ui->decodedTextLabel2->setVisible(false);
|
||||||
|
ui->label_6->setVisible(false);
|
||||||
|
ui->label_7->setVisible(false);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
void MainWindow::WSPR_config(bool b)
|
void MainWindow::WSPR_config(bool b)
|
||||||
|
@ -624,6 +624,12 @@ QLabel[oob="true"] {
|
|||||||
</item>
|
</item>
|
||||||
<item row="5" column="0">
|
<item row="5" column="0">
|
||||||
<widget class="LettersSpinBox" name="sbFtol">
|
<widget class="LettersSpinBox" name="sbFtol">
|
||||||
|
<property name="maximumSize">
|
||||||
|
<size>
|
||||||
|
<width>120</width>
|
||||||
|
<height>16777215</height>
|
||||||
|
</size>
|
||||||
|
</property>
|
||||||
<property name="toolTip">
|
<property name="toolTip">
|
||||||
<string>Frequency tolerance (Hz)</string>
|
<string>Frequency tolerance (Hz)</string>
|
||||||
</property>
|
</property>
|
||||||
@ -773,6 +779,12 @@ QLabel[oob="true"] {
|
|||||||
</item>
|
</item>
|
||||||
<item row="4" column="0">
|
<item row="4" column="0">
|
||||||
<widget class="QSpinBox" name="RxFreqSpinBox">
|
<widget class="QSpinBox" name="RxFreqSpinBox">
|
||||||
|
<property name="maximumSize">
|
||||||
|
<size>
|
||||||
|
<width>120</width>
|
||||||
|
<height>16777215</height>
|
||||||
|
</size>
|
||||||
|
</property>
|
||||||
<property name="toolTip">
|
<property name="toolTip">
|
||||||
<string>Audio Rx frequency</string>
|
<string>Audio Rx frequency</string>
|
||||||
</property>
|
</property>
|
||||||
|
@ -422,6 +422,15 @@ void CPlotter::DrawOverlay() //DrawOverlay()
|
|||||||
x2=XfromFreq(1600);
|
x2=XfromFreq(1600);
|
||||||
painter0.drawLine(x1,29,x2,29);
|
painter0.drawLine(x1,29,x2,29);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if(m_mode=="FreqCal") { //FreqCal
|
||||||
|
x1=XfromFreq(m_rxFreq-m_tol);
|
||||||
|
x2=XfromFreq(m_rxFreq+m_tol);
|
||||||
|
painter0.drawLine(x1,29,x2,29);
|
||||||
|
x1=XfromFreq(m_rxFreq);
|
||||||
|
painter0.drawLine(x1,24,x1,30);
|
||||||
|
}
|
||||||
|
|
||||||
if(m_mode=="JT9" or m_mode=="JT65" or m_mode=="JT9+JT65" or m_mode=="QRA64") {
|
if(m_mode=="JT9" or m_mode=="JT65" or m_mode=="JT9+JT65" or m_mode=="QRA64") {
|
||||||
|
|
||||||
if(m_mode=="QRA64" or (m_mode=="JT65" and m_bVHF)) {
|
if(m_mode=="QRA64" or (m_mode=="JT65" and m_bVHF)) {
|
||||||
|
Loading…
Reference in New Issue
Block a user