DSPSYSTEM Теория и практика цифровой обработки сигналов

Информация о пользователе

Привет, Гость! Войдите или зарегистрируйтесь.


Вы здесь » DSPSYSTEM Теория и практика цифровой обработки сигналов » Алгоритмы и их программирование » Фильтр Фарроу в Устройстве тактовой синхронизации (УТС)


Фильтр Фарроу в Устройстве тактовой синхронизации (УТС)

Сообщений 1 страница 5 из 5

1

Здраствуйте. Помогите разобраться с проблемой. Хочу использовать ресамплер в демодуляторе для подстройке по тактам. Ресамплер хочу реализовать на базе модифицированного фильтра Фарроу 3-го порядка. В схеме ресамплер стоит после КП (комплексного перемножителя) и ФНЧ. Соответственно ФД в ФАПЧ вычисляет ошибку по ресемплированным отсчётам. Реализацию ресамплера делал на базе кода который есть на этом сайте.
Теперь сама проблема.
Есть:
K=700 000; количество отсчётов
Fs0 = 294600 Гц;
Fs1 = 292000 Гц;
Ресамплер работает с массивом y0[i], который заполняется отсчётами последовательно после прохождения через КП и ФНЧ, тоесть поотсчётно.
Теперь если, например, при перерасчёте индекса исходного сигнала " int j = int((double)i*Fs0/Fs1)-2;") скажем 100 000-го получается j= 100 000*294600/292000 =100 888. Теперь получается что при расчёте коефициентов а3,а1,а2 нужны отсчёты которые находятся в массиве за адресом 100 888, 100 889, 100 890, 100 891, а там соответственно на 100 000 отсчёте в массиве y0[i] ещё нули :-( .
Как мне правильно сделать в моём случае. Или возможно я где то допустил ошибку при переводе из С++ в Дельфи.
Вот код Дельфи:
сам ресамплинг
for n:=0 to K-1 do
begin
t1[n]:=n/Fs1;
j:=(Round(n*Fs0/Fs1))-2;
if j<0 then j:=0;
x:=(((t1[n]-t0[j])*Fs0-2));
a3:=(y0[j+3]-y0[j])/6.0 +(y0[j+1]-y0[j+2])/2.0;
a1:=(y0[j+3]-y0[j+1])/2.0-a3;
a2:=y0[j+3]-a3-a1-y0[j+2];

y1:=x*(x*(x*a3+a2)+a1)+y0[j+2];
form1.Series3.AddXY(n,y1, '', clGreen);

Вышеуказанный код проверял отдельно при полностью заполненном массиве, всё работает. А как сделать в моём случае, по отсчётно не знаю, потому прошу Вашей помощи в решении этой проблемы. Заранее спасибо

0

2

думаю что для начала надо сделать так:

Код:
form1.Series3.AddXY(t1[n],y1, '', clGreen);

т.е. привязать не к номерам отсчетов а ко времени. Если код для полного массива работает, то и для каждого отсчета также должен работать

0

3

Пробовал привязать ко времени, то же самое.
Дело в том что получается при расчёте 100 000 отсчёта, нужно, я так понимаю,

a3:=(y0[100888+3]-y0[100888])/6.0 +(y0[100888+1]-y0[100888+2])/2.0;
a1:=(y0[100888+3]-y0[100888+1])/2.0-a3;
a2:=y0[100888+3]-a3-a1-y0[100888+2];
y1:=x*(x*(x*a3+a2)+a1)+y0[100888+2];
А у меня на это время через КП и ФНЧ пройдёт только 100 000 отсчёт и соответственно в  массиве y0, всё что за 100 000 отсчётом будут 0, в результате чего, у меня получается через определённое время на графике будет прямая линия

0

4

давайте посчитаем. n = 100000, тогда  t1[n] = n/Fs1 = 100000/292000  =0,34246575342465753424657534246575 сек.
в то же время j = 100888    и                 t0[j] = j/Fs0  = 100888/294600 =0,3424575695858791581805838424983   сек.

Т.о. 100888-й отсчет на входе будет во времени чуть раньше 100000-го отсчета на выходе. Это за счет того что частота дискретизации входного сигнала больше чем выходного. Поэтому когда вы будете рассчиывать 100000-й отсчет на выход, у вас уже будет 100888-й отсчет на входе.

0

5

Тема закрыта. Большое спасибо автору за помощь

0


Вы здесь » DSPSYSTEM Теория и практика цифровой обработки сигналов » Алгоритмы и их программирование » Фильтр Фарроу в Устройстве тактовой синхронизации (УТС)