久久久久久久999_99精品久久精品一区二区爱城_成人欧美一区二区三区在线播放_国产精品日本一区二区不卡视频_国产午夜视频_欧美精品在线观看免费

 找回密碼
 立即注冊

QQ登錄

只需一步,快速開始

搜索
查看: 1594|回復: 2
打印 上一主題 下一主題
收起左側

請問DSP中普通軟件鎖相環如何編寫?

[復制鏈接]
跳轉到指定樓層
樓主
請問DSP中普通軟件鎖相環如何編寫?
分享到:  QQ好友和群QQ好友和群 QQ空間QQ空間 騰訊微博騰訊微博 騰訊朋友騰訊朋友
收藏收藏 分享淘帖 頂 踩
回復

使用道具 舉報

沙發
ID:155507 發表于 2022-8-18 19:33 | 只看該作者
源代碼在單個文件中預先提供,并對其操作進行了完整描述。 編譯后,程序將運行鎖相環的模擬,生成一個數據文件,該文件可以使用 Gnuplot 或 Octave 繪制。

  1. // simulate a phase-locked loop
  2. #include <stdio.h>
  3. #include <stdlib.h>
  4. #include <complex.h>
  5. #include <math.h>

  6. int main() {
  7.     // parameters
  8.     float        phase_offset     = 0.00f;  // carrier phase offset
  9.     float        frequency_offset = 0.30f;  // carrier frequency offset
  10.     float        wn               = 0.01f;  // pll bandwidth
  11.     float        zeta             = 0.707f; // pll damping factor
  12.     float        K                = 1000;   // pll loop gain
  13.     unsigned int n                = 400;    // number of samples

  14.     // generate loop filter parameters (active PI design)
  15.     float t1 = K/(wn*wn);   // tau_1
  16.     float t2 = 2*zeta/wn;   // tau_2

  17.     // feed-forward coefficients (numerator)
  18.     float b0 = (4*K/t1)*(1.+t2/2.0f);
  19.     float b1 = (8*K/t1);
  20.     float b2 = (4*K/t1)*(1.-t2/2.0f);

  21.     // feed-back coefficients (denominator)
  22.     //    a0 =  1.0  is implied
  23.     float a1 = -2.0f;
  24.     float a2 =  1.0f;

  25.     // print filter coefficients (as comments)
  26.     printf("#  b = [b0:%12.8f, b1:%12.8f, b2:%12.8f]\n", b0, b1, b2);
  27.     printf("#  a = [a0:%12.8f, a1:%12.8f, a2:%12.8f]\n", 1., a1, a2);

  28.     // filter buffer
  29.     float v0=0.0f, v1=0.0f, v2=0.0f;
  30.    
  31.     // initialize states
  32.     float phi     = phase_offset;   // input signal's initial phase
  33.     float phi_hat = 0.0f;           // PLL's initial phase
  34.    
  35.     // run basic simulation
  36.     unsigned int i;
  37.     float complex x, y;
  38.     printf("# %6s %12s %12s %12s %12s %12s\n",
  39.             "index", "real(x)", "imag(x)", "real(y)", "imag(y)", "error");
  40.     for (i=0; i<n; i++) {
  41.         // compute input sinusoid and update phase
  42.         x = cosf(phi) + _Complex_I*sinf(phi);
  43.         phi += frequency_offset;

  44.         // compute PLL output from phase estimate
  45.         y = cosf(phi_hat) + _Complex_I*sinf(phi_hat);

  46.         // compute error estimate
  47.         float delta_phi = cargf( x * conjf(y) );

  48.         // print results to standard output
  49.         printf("  %6u %12.8f %12.8f %12.8f %12.8f %12.8f\n",
  50.             i, crealf(x), cimagf(x), crealf(y), cimagf(y), delta_phi);

  51.         // push result through loop filter, updating phase estimate
  52.         v2 = v1;  // shift center register to upper register
  53.         v1 = v0;  // shift lower register to center register
  54.         v0 = delta_phi - v1*a1 - v2*a2; // compute new lower register

  55.         // compute new output
  56.         phi_hat = v0*b0 + v1*b1 + v2*b2;
  57.     }
  58.     return 0;
  59. }
復制代碼

liquid_pll_example.zip

3.18 KB, 下載次數: 10

9_sithamparanathan.pdf

321.58 KB, 下載次數: 8

abineau_dpll_analysis.pdf

557.39 KB, 下載次數: 8

回復

使用道具 舉報

板凳
ID:123289 發表于 2022-8-19 11:31 | 只看該作者
需帶有鎖相環的芯片,才行。依芯片手冊操作。
回復

使用道具 舉報

您需要登錄后才可以回帖 登錄 | 立即注冊

本版積分規則

手機版|小黑屋|51黑電子論壇 |51黑電子論壇6群 QQ 管理員QQ:125739409;技術交流QQ群281945664

Powered by 單片機教程網

快速回復 返回頂部 返回列表
主站蜘蛛池模板: 亚洲三级av | 国产成人综合一区二区三区 | 国产在线二区 | 成人欧美一区二区三区黑人孕妇 | 艹逼网| 二区亚洲 | 国产成人网| 成人在线免费看 | 国产日韩欧美在线一区 | 亚洲影音| 91国在线观看| 91pao对白在线播放 | 日韩视频免费 | 亚洲美乳中文字幕 | 精品无码久久久久久国产 | 国产电影一区二区 | 免费特级黄毛片 | 毛片免费观看 | 四虎影院在线观看av | 亚洲福利在线观看 | 亚洲xxxxx| 成人老司机| 精品亚洲一区二区三区四区五区 | 久久里面有精品 | av手机免费在线观看 | 午夜男人免费视频 | 成人精品鲁一区一区二区 | 精品一级毛片 | 91九色porny首页最多播放 | 成人亚洲视频 | 欧美一区二区 | 99在线国产| 中文字幕 在线观看 | 午夜寂寞影院在线观看 | 91久久久久久 | 超碰日本 | 另类在线 | 日本一二区视频 | 免费在线观看av网站 | 久国久产久精永久网页 | www.天天操.com|