реклама на сайте
подробности

 
 
> Трансивер SX1276, Корректировка частоты приёма в SX1276.
JohnKorsh
сообщение Feb 6 2017, 18:00
Сообщение #1


Частый гость
**

Группа: Свой
Сообщений: 182
Регистрация: 6-01-05
Из: Россия, Москва
Пользователь №: 1 820



Добрый день! Работает ли кто с SX1276 от SemTech? Это LoRa трансивер. Если да, то как правильно скорректировать частоту приёма? Поясню, чего хочу: ФАПЧ там разомкнута. "Замыкать" её должен разработчик программного обеспечения. Процесс следующий: во время приёма преамбулы (в регистрах есть соответствующий флажок) я должен считать показания регистра ошибки по частоте (20 бит), посчитать численное значение корректировки по приведённой в DataSheet формуле, вычесть его из текущего значения регистра несущей и вписать его туда. При тщательном следовании DataSheet, после корректировки, частота приёма сдвигается настолько, что сам приём становится невозможным. Может кто сталкивался и решил задачу? (На SemTech написал, пока не ответили). Да, при этом Kit работает отлично, но коды в микроконтроллере прикрыты.
Go to the top of the page
 
+Quote Post
 
Start new topic
Ответов
dontsov
сообщение Jun 7 2018, 08:45
Сообщение #2


Участник
*

Группа: Участник
Сообщений: 28
Регистрация: 25-11-17
Пользователь №: 100 351



Коллеги, купил из разных партий BSFrance Lora32u4 HDP13 (sx1276).
Не мог понять, почему друг друга не слышат, включил ФМ приёмник на 868мгц и слышу, что несущая частота у них отличается : у одного экземпляра вместо заданной мной 868 вообще 866.7..

SX1276 как-то калибруется?
Go to the top of the page
 
+Quote Post
JohnKorsh
сообщение Jul 17 2018, 10:13
Сообщение #3


Частый гость
**

Группа: Свой
Сообщений: 182
Регистрация: 6-01-05
Из: Россия, Москва
Пользователь №: 1 820



Добрый день!
Код, приведённый выше не работает. Кто работал с SX1276-79, гляньте, пожалуйста, может поправите меня?
Результат уж больно крамольный - ошибка в DataSheet.
Отвечу на вопросы выше - корректировка нужна, в основном, при работе в узкой полосе - 7,8 КГц. и около - чутьё максимальное, но, для такой полосы надо либо
TCXo с bpm, либо подстраивать, как указано в DataSheet. При кварцевых резонаторах видно на спектроанализаторе значительное различие несущих.
При более широких полосах ppm кварцевого генератора вполне достаточно.
В 8-битный регистр коррекции ppm пишется отклонения тактовой частоты в ppm, а не корректировка несущей.
Повторюсь, в SX1276-SX1278 не замкнута петля ФАПЧ по несущей частоте. Это должен делать программист, считывая после
принятия преамбулы, значение разницы частот приёмника и передатчика и самостоятельно добавляя (или вычитая)
это число из текущей установки частоты. Предварительно умножив на коэффициент, зависящий от установленной полосы.
Второй раз такое встречаю и именно в трансивере с ЛЧМ (первый раз - Nanotron).
Попутный вопрос - не объяснит ли кто, почему так, то есть, что стоит фирме сделать это на аппаратном уровне,
чтобы пользователь и не знал?

Формула для расчёта коэффициента пропорциональности между отсчётом и требуемой корректировкой из DataSheet:
Ferr = (([Value]*2^24)/Fxtal) * (BW [KHz]/500) (1)
где:
Value – число, считанное из регистров коррекции частоты [28,29,2A];
Fxtal – частота опорного кварца (32 000 000 Гц);
BW – диапазон в КГц.
Ferr – число, которое нужно добавлять (вычитать) к значениям регистров, задающих частоту [6,7,8].

По DataShet приёмник допускает отклонения +/- 25% от ширины полосы приёмника (стр. 37).
При использовании формулы (1) сдвиг частоты намного превышает +/-25% от ширины полосы приёмника.
Вне зависимости от режимов работы трансивера шаг подстройки синтезатора остаётся постоянным и
равным 61 Гц. Следовательно, можно подсчитать требуемый коэффициент пропорциональности.
Длина регистра отсчётов коррекции частоты 20 бит, включая знаковый бит - диапазон изменения
отсчётов +/-2^19 = +/-524288. Из этого можно вывести коэффициент пропорциональности между
отсчётом регистра коррекции частоты [28,29,2A] и требуемым значением корректировки частоты,
которое нужно добавлять (или вычитать) из текущего значения [6,7,8]:

Для диапазона 7,8 КГц вот что получается:
7,8 КГц * 0,25 = 1,95 КГц
Шаг синтезатора 61 Гц, следовательно, показания отсчёта корректировки не должны быть больше
1,95/61=31,96, приблизительно, 32.
Следовательно, корректировочный коэффициент должен быть
524288/32=0,000061035, а по формуле (1) это 0,008179. Это в 134 раза больше.

Расчёты проведены для всех режимов работы - и всегда данные по формуле (1) надо делить на 134, то есть формула должна
иметь вид:
Ferr = (([Value]*2^24)/Fxtal) * (BW [KHz]/67000) (2)
Если частота передатчика ниже частоты приёмника, то отсчёт положительный – в старшем разряде 0.
Число из [28,29,2A], после умножения на коэффициент, надо вычитать из содержимого регистров, определяющих частоту.
Если частота передатчика выше частоты приёмника, то отсчёт отрицательный – в старшем разряде 1.
Полученное число, после умножения на коэффициент, надо добавлять к содержимому регистров, определяющих частоту,
предварительно отбросив знаковый разряд и преобразовав результат из дополнительного кода.
Проверил на практике - работает (если по формуле - приём разваливается после первой же корректировки частоты).
Хотелось бы, чтобы кто-то поправил - как то не верится в ошибку в DataSheet.



Да, конечное, 32/524288, а не 524288/32, приношу извинения.
Go to the top of the page
 
+Quote Post



Reply to this topicStart new topic
1 чел. читают эту тему (гостей: 1, скрытых пользователей: 0)
Пользователей: 0

 


RSS Текстовая версия Сейчас: 24th July 2025 - 11:55
Рейтинг@Mail.ru


Страница сгенерированна за 0.01369 секунд с 7
ELECTRONIX ©2004-2016