0

400MHz で記録するように USRP をセットアップし、データを正しく受信しています。次に、USRP を 400MHz + 18kHz オフセットで記録するように設定すると、recv() コマンドで TIMEOUT エラーが発生します。

以前の周波数と同じコードを使用して新しい周波数を設定しているため、この例で変更するのはそれだけです。

新しい周波数に到達するために行わなければならないクリーンアップまたは 2 秒ほど長いホールド タイムはありますか?

インターフェイス クラスが構築されると、次の行を使用して初期化します

  uhd::set_thread_priority_safe();

  // Setup device addresses and create object
  uhd::device_addr_t devAddr;
  devAddr["addr0"] = "192.168.10.2";
  devAddr["addr1"] = "192.168.20.2";
  devAddr["addr2"] = "192.168.30.2";

  m_usrp = uhd::usrp::multi_usrp::make(devAddr);

  uhd::usrp::subdev_spec_t rxSpec("A:0");
  m_usrp->set_rx_subdev_spec(rxSpec);

  m_usrp->set_clock_source("external");
  m_usrp->set_time_source("external");
  m_usrp->set_rx_rate(m_sampleRate);  //Sample rate is 500000

次の行を使用して、特定のデータ キャプチャを準備します。set と gets は、小数点が少し異なります。

  uhd::stream_args_t streamArgs("fc32");
  for (size_t chan = 0; chan < m_usrp->get_rx_num_channels(); chan++)
  {
    streamArgs.channels.push_back(chan);
  }

  m_rxStreamer = m_usrp->get_rx_stream(streamArgs);

  m_usrp->set_rx_gain(m_gainChannel1, 0); // All gains set to 31.5
  m_usrp->set_rx_gain(m_gainChannel2, 1);
  m_usrp->set_rx_gain(m_gainChannel3, 2);

  uhd::time_spec_t cmdTime = m_usrp->get_time_now() + uhd::time_spec_t(1.0);
  m_usrp->set_command_time(cmdTime);
  m_usrp->set_rx_freq(m_freqChannel1 - CENTER_FREQ_OFFSET_HZ, 0); // Freq is 400000000 and CENTER_FREQ is 100000
  m_usrp->set_rx_freq(m_freqChannel2 - CENTER_FREQ_OFFSET_HZ, 1);
  m_usrp->set_rx_freq(m_freqChannel3 - CENTER_FREQ_OFFSET_HZ, 2);
  m_usrp->clear_command_time();

  sleep(1);

  double actualChannel0Freq = m_usrp->get_rx_freq(0);
  double actualChannel1Freq = m_usrp->get_rx_freq(1);
  double actualChannel2Freq = m_usrp->get_rx_freq(2);

  LOG(INFO) << "Acutal tuned USRP frequencies " << std::fixed << actualChannel0Freq << " " << actualChannel1Freq << " " << actualChannel2Freq;

以下を使用してデータの取得を開始するとき:

      uhd::rx_metadata_t md;
      double timeout = 5.0;

        size_t samplesRxThisTime = m_rxStreamer->recv(buffPtrs, sampsThisTime, md, timeout);

        // Smaller timeout for subsequent packets
        timeout = 0.75;

        // Handle any error codes
        if (md.error_code == uhd::rx_metadata_t::ERROR_CODE_TIMEOUT)
        {
          LOG(ERROR) << "Timed out while receiving data from USRPs";
          break;
        }

周波数を少し変更しても問題は発生しないと予想していました。元の頻度は機能しますが、更新された頻度は機能しません。

4

1 に答える 1