01.10.2011 Программный приёмник выложен в SVN
Korogodin (обсуждение | вклад) (→Задачи по развитию проекта) |
Korogodin (обсуждение | вклад) (→Где взять исходники) |
||
Строка 26: | Строка 26: | ||
1. Создать рабочий каталог (допустим, SR31): | 1. Создать рабочий каталог (допустим, SR31): | ||
− | < | + | <syntaxhighlight lang="bash"> |
mkdir SR31 | mkdir SR31 | ||
− | </ | + | </syntaxhighlight> |
2. Создать каталог для исходных файлов: | 2. Создать каталог для исходных файлов: | ||
− | < | + | <syntaxhighlight lang="bash"> |
cd SR31 | cd SR31 | ||
svn co svn://193.233.71.244:4000/SR31/trunk/ . | svn co svn://193.233.71.244:4000/SR31/trunk/ . | ||
− | </ | + | </syntaxhighlight> |
При выполнении данной команды будет запрошен логин и пароль. Пароли и явки каждому будут | При выполнении данной команды будет запрошен логин и пароль. Пароли и явки каждому будут | ||
Строка 44: | Строка 44: | ||
3. Создать каталог для данных | 3. Создать каталог для данных | ||
− | < | + | <syntaxhighlight lang="bash"> |
mkdir data | mkdir data | ||
− | </ | + | </syntaxhighlight> |
4. Скопировать в каталог с данными выборку сигнала. На данный момент в программу задано, | 4. Скопировать в каталог с данными выборку сигнала. На данный момент в программу задано, | ||
что файлы называются data/sigs.bin и data/mags.bin | что файлы называются data/sigs.bin и data/mags.bin | ||
− | 5. Скачать, скомпилировать библиотеку [http://www.fftw.org fftw] и положить результат (файлы fftw3.h и libfftw3.a) в каталог <code>./lib/fftw3</code> | + | 5. Поставить библиотеку fftw3-dev: |
+ | <syntaxhighlight lang="bash"> | ||
+ | sudo apt-get install fftw3-dev | ||
+ | </syntaxhighlight> | ||
+ | |||
+ | Резервный вариант: Скачать, скомпилировать библиотеку [http://www.fftw.org fftw] и положить результат (файлы fftw3.h и libfftw3.a) в каталог <code>./lib/fftw3</code>, поправить makefile | ||
6. Дальше нужно зайти в каталог work и дать команду: | 6. Дальше нужно зайти в каталог work и дать команду: | ||
− | < | + | <syntaxhighlight lang="bash"> |
make | make | ||
− | </ | + | </syntaxhighlight> |
Данная команда скомпилирует программу и создаст в каталоге bin исполняемые файлы. Дальше нужно получить права root. Обычно это делается командой: | Данная команда скомпилирует программу и создаст в каталоге bin исполняемые файлы. Дальше нужно получить права root. Обычно это делается командой: | ||
− | < | + | <syntaxhighlight lang="bash"> |
su | su | ||
− | </ | + | </syntaxhighlight> |
В системе Ubuntu работа с правами root не разрешается, тогда нужно сделать так: | В системе Ubuntu работа с правами root не разрешается, тогда нужно сделать так: | ||
− | < | + | <syntaxhighlight lang="bash"> |
sudo bash | sudo bash | ||
− | </ | + | </syntaxhighlight> |
или запускать саму программу через <code>sudo</code>: | или запускать саму программу через <code>sudo</code>: | ||
− | <code> | + | <code lang="bash"> |
name@host:path/bin$ sudo ./emu_receiver | name@host:path/bin$ sudo ./emu_receiver | ||
</code> | </code> |
Версия 13:20, 13 октября 2011
|
Решено оживить проект программного приёмника. Теперь цель - обучение студентов и выполнение научных исследований.
Состояние приёмника на сегодня
На данный момент программный приёмник работает и выполняет свою основную функцию - решает навигационную задачу. Входной сигнал, принятый радиочастотным блоком, передаётся в ЭВМ по шине USB. Приёмник работает в режиме реального времени. Работа осуществляется по сигналам GPS C/A.
Возможен второй вариант использования приёмника. Выборка сигнала записывается на жёсткий диск, а потом возможна работа программного приёмника по записанной в файл выборке (также в реальном времени).
Где взять исходники
Я подчистил исходники, выкинул всё, что не нужно. Удалил все бинарные файлы. Вычистил всё, что взязано с Plx (RIP PlxPci - не думаю, что кто-то будет жалеть...).
Результат выложил в SVN. Пока проект называется SR31. Посмотреть его содержимое, при наличии пары логин/пароль, можно тут: SR31
Так как же получить исходники? Во-первых, вам нужен Linux. Это первое и главное. Дальше всё просто.
1. Создать рабочий каталог (допустим, SR31):
2. Создать каталог для исходных файлов:
svn co svn://193.233.71.244:4000/SR31/trunk/ .
При выполнении данной команды будет запрошен логин и пароль. Пароли и явки каждому будут выдаваться отдельно.
Если нужно работать с записанными выборками данных (а не с платой USB), то надо:
3. Создать каталог для данных
4. Скопировать в каталог с данными выборку сигнала. На данный момент в программу задано, что файлы называются data/sigs.bin и data/mags.bin
5. Поставить библиотеку fftw3-dev:
Резервный вариант: Скачать, скомпилировать библиотеку fftw и положить результат (файлы fftw3.h и libfftw3.a) в каталог ./lib/fftw3
, поправить makefile
6. Дальше нужно зайти в каталог work и дать команду:
Данная команда скомпилирует программу и создаст в каталоге bin исполняемые файлы. Дальше нужно получить права root. Обычно это делается командой:
В системе Ubuntu работа с правами root не разрешается, тогда нужно сделать так:
или запускать саму программу через sudo
:
name@host:path/bin$ sudo ./emu_receiver
В каталоге bin находятся необходимые программы: usb_receiver, emu_receiver и прочее.
Работа с приёмником
Предполагается два варианта работы - по реальному сигналу с платой USB и по записанному в файл сигналу.
Работа по реальному сигналу
Для работы по реальному сигналу необходима плата ввода данных USB. Сейчас эти платы изготавливаются, ответственный и разработчик - Иван Липа. Платы должны быть готовы примерно через месяц.
Плата ввода данных по-крупному состоит из двух частей (кстати, она даже реально состоит из двух частей ;). Первая часть - радиочастотный блок приёмника со всеми его функциями - усиление сигнала, перенос по частоте, фильтрация, АЦП... Вторая часть - интерфейс ввода данных, передающий оцифрованный поток в компьютер.
Для работы с этой платой необходимо:
- загрузить модуль ядра usb40;
- настроить udev;
- подключить плату к USB;
- запустить приёмник usb_receiver.
Первые два пункта, естественно, нужно делать только один раз при настройке. Исходники модуля ядра я пока не выложил в SVN, предполагаю включить их в проект.
Проект надо запускать из-под root, иначе работать нормально не будет. Тут дело в том, что приёмник устанавливает себе повышенный приоритет, а это позволяется только программам с правами root. (Интересно, поможет ли тут SUID? Надо попробовать...)
Работа по выборке данных из файла
Выборки данных храняться в каталоге data. Выборка данных состоит из двух файлов. Один файл содержит отсчёты знака входного сигнала (sigs), второй файл - отсчёты амплитуды (mags). Странно, но так уж повелось...
Как можно получить выборку сигнала? Тут есть два варианта.
Первый вариант - записать из эфира. Для этого нужна плата ввода данных и программа download, входящая в проект приёмника. Можно записать выборку такой длины, на которую хватит места на диске. Ранее было сделано несколько выборок данных, их можно использовать в работе.
Второй вариант - сформировать выборку в модели. В состав программного приёмника входит программа для формирования такой выборки - sim.c.
Задачи по развитию проекта
Актуальные задачи:
- совершенствование самого софта программного приёмника (особенно в части стабильности);
- графический интерфейс на qt;
- перенести функцию оценивания отношения сигнал/шум;
- плата ввода данных;
- загрузочный диск Linux с необходимым софтом;
- написание документации.
На первом этапе нужно снять характеристики приёмника - TTFF, чувствительность, точность и составить сравнительную таблицу с другими приёмниками, чтобы ни у кого не было иллюзий.
Название
Кстати. Затеяв данное мероприятие, мы столкнулись с серьёзной проблемой. Нынешний программный приёмник был создан ещё в 2007 году, но до сих пор не получил нормального названия. У меня, например, все эти годы проект лежал в каталоге "Receiver_pure". Звучного названия, вроде "Альпака", до сих пор нет. Пока я назвал проект SR31. SR - "Software receiver". 31 - это просто цифра для солидности.
Так что объявляется конкурс на название программного приёмника ;)
UPDATE. 10.10.2011 Поздно, название уже определено - SR31.
[ Хронологический вид ]Комментарии
Тут небольшая проблема - у студентов нет доступа к WebSVN
Надо им раздать пароли - только индивидуальные! И не на все проекты.
На WebSVN пароль реализован средствами Апача. Он просто не дает запустить сам WebSVN. Пока не вижу пути, как запаролить в WebSVN отдельные проекты.
А можно ли, допустим, запустить два WebSVN с разными паролями? Или при таком подходе вообще два Апача понадобиться?
А вот это не подойдёт? http://stackoverflow.com/questions/939119/how-do-i-restrict-repository-access-via-websvn Там ведь указыватся путь к хранилищу SVN и файл с паролями. Может быть, сделать такие конфиги отдельные для каждого проекта?
Примерно так:
<Location /svn1>
...
AuthUserFile "/svn1/secret"
</Location>
<Location /svn2>
...
AuthUserFile "/svn2/secret"
</Location>
Идея понятна, нужно пробовать и разбираться.
Войдите, чтобы комментировать.