2015-12-02 01:04:04 -05:00
|
|
|
/*
|
|
|
|
* Copyright (C) 2014 Jared Boone, ShareBrained Technology, Inc.
|
|
|
|
*
|
|
|
|
* This file is part of PortaPack.
|
|
|
|
*
|
|
|
|
* This program is free software; you can redistribute it and/or modify
|
|
|
|
* it under the terms of the GNU General Public License as published by
|
|
|
|
* the Free Software Foundation; either version 2, or (at your option)
|
|
|
|
* any later version.
|
|
|
|
*
|
|
|
|
* This program is distributed in the hope that it will be useful,
|
|
|
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
|
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
|
|
* GNU General Public License for more details.
|
|
|
|
*
|
|
|
|
* You should have received a copy of the GNU General Public License
|
|
|
|
* along with this program; see the file COPYING. If not, write to
|
|
|
|
* the Free Software Foundation, Inc., 51 Franklin Street,
|
|
|
|
* Boston, MA 02110-1301, USA.
|
|
|
|
*/
|
|
|
|
|
2015-12-08 18:28:33 -05:00
|
|
|
#include "analog_audio_app.hpp"
|
2015-12-02 01:04:04 -05:00
|
|
|
|
|
|
|
#include "portapack.hpp"
|
2016-01-03 15:47:22 -05:00
|
|
|
#include "portapack_shared_memory.hpp"
|
2015-12-02 01:04:04 -05:00
|
|
|
using namespace portapack;
|
|
|
|
|
2016-01-29 18:57:20 -05:00
|
|
|
#include "dsp_fir_taps.hpp"
|
|
|
|
#include "dsp_iir_config.hpp"
|
|
|
|
|
2015-12-02 01:04:04 -05:00
|
|
|
#include "utility.hpp"
|
|
|
|
|
|
|
|
AnalogAudioModel::AnalogAudioModel(ReceiverModel::Mode mode) {
|
|
|
|
receiver_model.set_baseband_configuration({
|
|
|
|
.mode = toUType(mode),
|
|
|
|
.sampling_rate = 3072000,
|
2015-12-29 13:55:55 -05:00
|
|
|
.decimation_factor = 1,
|
2015-12-02 01:04:04 -05:00
|
|
|
});
|
|
|
|
receiver_model.set_baseband_bandwidth(1750000);
|
2016-01-03 15:47:22 -05:00
|
|
|
|
2016-01-03 16:38:55 -05:00
|
|
|
switch(mode) {
|
|
|
|
case ReceiverModel::Mode::NarrowbandFMAudio:
|
2016-01-30 00:05:43 -05:00
|
|
|
configure_nbfm(2);
|
2016-01-03 16:38:55 -05:00
|
|
|
break;
|
|
|
|
|
|
|
|
case ReceiverModel::Mode::WidebandFMAudio:
|
|
|
|
configure_wfm();
|
|
|
|
break;
|
|
|
|
|
2016-01-03 17:31:39 -05:00
|
|
|
case ReceiverModel::Mode::AMAudio:
|
|
|
|
configure_am();
|
|
|
|
break;
|
|
|
|
|
2016-01-03 16:38:55 -05:00
|
|
|
default:
|
|
|
|
break;
|
2016-01-03 15:47:22 -05:00
|
|
|
}
|
2016-01-03 16:38:55 -05:00
|
|
|
|
|
|
|
}
|
|
|
|
|
2016-01-30 00:05:43 -05:00
|
|
|
struct NBFMMode {
|
|
|
|
const fir_taps_real<24> decim_0;
|
|
|
|
const fir_taps_real<32> decim_1;
|
|
|
|
const fir_taps_real<32> channel;
|
|
|
|
const size_t deviation;
|
|
|
|
};
|
|
|
|
|
|
|
|
static constexpr std::array<NBFMMode, 3> nbfm_mode_configs { {
|
|
|
|
{ taps_4k25_decim_0, taps_4k25_decim_1, taps_4k25_channel, 2500 },
|
|
|
|
{ taps_11k0_decim_0, taps_11k0_decim_1, taps_11k0_channel, 2500 },
|
|
|
|
{ taps_16k0_decim_0, taps_16k0_decim_1, taps_16k0_channel, 5000 },
|
|
|
|
} };
|
|
|
|
|
|
|
|
void AnalogAudioModel::configure_nbfm(const size_t index) {
|
|
|
|
const auto config = nbfm_mode_configs[index];
|
2016-01-03 16:38:55 -05:00
|
|
|
const NBFMConfigureMessage message {
|
2016-01-30 00:05:43 -05:00
|
|
|
config.decim_0,
|
|
|
|
config.decim_1,
|
|
|
|
config.channel,
|
2016-01-29 22:23:30 -05:00
|
|
|
2,
|
2016-01-30 00:05:43 -05:00
|
|
|
config.deviation,
|
2016-01-29 22:23:30 -05:00
|
|
|
audio_24k_hpf_300hz_config,
|
|
|
|
audio_24k_deemph_300_6_config
|
2016-01-03 16:38:55 -05:00
|
|
|
};
|
|
|
|
shared_memory.baseband_queue.push(message);
|
2016-01-29 22:23:30 -05:00
|
|
|
clock_manager.set_base_audio_clock_divider(2);
|
2016-01-03 16:38:55 -05:00
|
|
|
}
|
|
|
|
|
|
|
|
void AnalogAudioModel::configure_wfm() {
|
|
|
|
const WFMConfigureMessage message {
|
|
|
|
taps_200k_wfm_decim_0,
|
|
|
|
taps_200k_wfm_decim_1,
|
|
|
|
taps_64_lp_156_198,
|
|
|
|
75000,
|
2016-01-29 18:57:20 -05:00
|
|
|
audio_48k_hpf_30hz_config,
|
|
|
|
audio_48k_deemph_2122_6_config
|
2016-01-03 16:38:55 -05:00
|
|
|
};
|
|
|
|
shared_memory.baseband_queue.push(message);
|
2016-01-29 18:33:01 -05:00
|
|
|
clock_manager.set_base_audio_clock_divider(1);
|
2015-12-02 01:04:04 -05:00
|
|
|
}
|
2016-01-03 17:31:39 -05:00
|
|
|
|
|
|
|
void AnalogAudioModel::configure_am() {
|
|
|
|
const AMConfigureMessage message {
|
|
|
|
taps_6k0_decim_0,
|
|
|
|
taps_6k0_decim_1,
|
2016-01-30 20:28:11 -05:00
|
|
|
taps_6k0_decim_2,
|
2016-01-30 20:30:54 -05:00
|
|
|
taps_2k8_usb_channel,
|
2016-01-30 21:02:28 -05:00
|
|
|
AMConfigureMessage::Modulation::SSB,
|
2016-01-29 22:23:30 -05:00
|
|
|
audio_12k_hpf_300hz_config
|
2016-01-03 17:31:39 -05:00
|
|
|
};
|
|
|
|
shared_memory.baseband_queue.push(message);
|
2016-01-29 22:23:30 -05:00
|
|
|
clock_manager.set_base_audio_clock_divider(4);
|
2016-01-03 17:31:39 -05:00
|
|
|
}
|