Что можно урезать в Linux/LinuxCNC, чтобы сделать меньше Lat

Обсуждение установки, настройки и использования LinuxCNC. Вопросы по Gкоду.
Аватара пользователя
Lexxa
Мастер
Сообщения: 2703
Зарегистрирован: 16 дек 2011, 16:48
Репутация: 319
Настоящее имя: Алексей
Откуда: ryazan
Контактная информация:

Что можно урезать в Linux/LinuxCNC, чтобы сделать меньше Lat

Сообщение Lexxa »

UAVpilot писал(а):
Lexxa писал(а):Итак, имеем Linuxcnc на P4 2400MHz, который тормозит и HH320 на Celeron 400MHz без тормозов.
Я могу обычный Linux так урезать, оставив только самое необходимое, что он будет резвее HH320 на том-же Celeron 400MHz, но это нафик не надо.
Lexxa писал(а):Согласен, но нужны ли такие короткие времена?
А как-же
Lexxa писал(а):Он каждую нс не 1 дискрету едет, а получает новое положение, в котором может быть и 1 и 1000 дискрет. Там все на ПЛИС.
? :)
UAVpilot,
Ну так скажи что урезать, я попробую, ибо это надо.

Почему ни НН320 (3мс), ни НН620 (3мс) ни ННi530 (3 мс, опционально 0.1), ни sinumerik 828 (3 мс интерполятор/125мкс серво) такие короткие времена тактов не нужны.
Что будет если у линукс цнц такт по положению сделать тоже 3 мс?
Тема отделена от: Re: Halcompail и драйвер. #108
:bender:
Аватара пользователя
Serg
Мастер
Сообщения: 21923
Зарегистрирован: 17 апр 2012, 14:58
Репутация: 5183
Заслуга: c781c134843e0c1a3de9
Настоящее имя: Сергей
Откуда: Москва
Контактная информация:

Re: Halcompail и драйвер.

Сообщение Serg »

Lexxa писал(а):Ну так скажи что урезать, я попробую, ибо это надо.
Много чего, например надо ядро пересобрать повыключав всё, что не используется... Я б не советовал делать это, если не знаешь как это делать и хорошо не знаешь "железо", чипсет и т.п. - можно что-нибудь нужное отключить...
Lexxa писал(а):Что будет если у линукс цнц такт по положению сделать тоже 3 мс?
Будет работать, если производительности хватит. :) Это зависит и от кофигурации компа и от конфигурации LinuxCNC (сколько задействовано компонентов и каких).
Я не Христос, рыбу не раздаю, но могу научить, как сделать удочку...
Аватара пользователя
PKM
Почётный участник
Почётный участник
Сообщения: 4263
Зарегистрирован: 31 мар 2011, 18:11
Репутация: 705
Настоящее имя: Андрей
Откуда: Украина
Контактная информация:

Re: Halcompail и драйвер.

Сообщение PKM »

Обычно такт 1мс, почему вдруг на 3мс не хватит производительности?
Аватара пользователя
Serg
Мастер
Сообщения: 21923
Зарегистрирован: 17 апр 2012, 14:58
Репутация: 5183
Заслуга: c781c134843e0c1a3de9
Настоящее имя: Сергей
Откуда: Москва
Контактная информация:

Re: Halcompail и драйвер.

Сообщение Serg »

Я понял, что речь про [TASK]CYCLE_TIME
Я не Христос, рыбу не раздаю, но могу научить, как сделать удочку...
Аватара пользователя
Lexxa
Мастер
Сообщения: 2703
Зарегистрирован: 16 дек 2011, 16:48
Репутация: 319
Настоящее имя: Алексей
Откуда: ryazan
Контактная информация:

Re: Halcompail и драйвер.

Сообщение Lexxa »

UAVpilot писал(а): про [TASK]CYCLE_TIME
Нет, про [EMCMOT]TRAJ_PERIOD = 100000
UAVpilot писал(а):Много чего, например надо ядро пересобрать повыключав всё, что не используется... Я б не советовал делать это, если не знаешь как это делать и хорошо не знаешь "железо", чипсет и т.п. - можно что-нибудь нужное отключить...
ну так не только ж в ядре дело, а в сервисах ненужных. как узнать нужные и не нужные?
UAVpilot писал(а): если производительности хватит.
Ты хочешь сказать, что че период больше, тем выше производительность железа нужна, проясни я не понял чет немного
:bender:
Аватара пользователя
Serg
Мастер
Сообщения: 21923
Зарегистрирован: 17 апр 2012, 14:58
Репутация: 5183
Заслуга: c781c134843e0c1a3de9
Настоящее имя: Сергей
Откуда: Москва
Контактная информация:

Re: Halcompail и драйвер.

Сообщение Serg »

Ну не принципиально :)
Смысл в том, что было 10 мс, а станет 3 мс.

Списка ненужных сервисов пока никто не составил... :) Придётся во всё вникать самостоятельно и принимать решение что нужно, а что нет.
Я не Христос, рыбу не раздаю, но могу научить, как сделать удочку...
Аватара пользователя
Lexxa
Мастер
Сообщения: 2703
Зарегистрирован: 16 дек 2011, 16:48
Репутация: 319
Настоящее имя: Алексей
Откуда: ryazan
Контактная информация:

Re: Halcompail и драйвер.

Сообщение Lexxa »

[EMCMOT]TRAJ_PERIOD = 100000 нс = 100 мкс = 0.1 мс!!!
[EMCMOT]SERVO_PERIOD = 1000000 нс =1000 мкс = 1 мс.
У сименса 3 мс и 125мкс соответственно!!!
:bender:
Аватара пользователя
Nick
Мастер
Сообщения: 22776
Зарегистрирован: 23 ноя 2009, 16:45
Репутация: 1735
Заслуга: Developer
Откуда: Gatchina, Saint-Petersburg distr., Russia
Контактная информация:

Re: Halcompail и драйвер.

Сообщение Nick »

Lexxa писал(а):Очень для меня странно, что servo thread величина плюс минус километр. Я как то раньше думал, что это главный параметр быстродействия.
Сам servo-period плавает. Но в определенных пределах. При этом мы знаем на сколько уплыл текущий период.
Т.е. погрешность будет только в пределах 1-2 периодов. Что при этом имеем:
1. Запросим у FPGA инфу на +-25мкс раньше
2. Все рассчеты будут начинаться +-25мкс.
3. Отправим команду в FPGA на +-25мкс раньше

Далее, у FPGA период не плавает. Он может точно отсчитать начало нового периода и начнет действовать ровно тогда, когда это нужно. Поэтому влияние плавания комповского сервопериода на нем не скажется.
Аватара пользователя
Nick
Мастер
Сообщения: 22776
Зарегистрирован: 23 ноя 2009, 16:45
Репутация: 1735
Заслуга: Developer
Откуда: Gatchina, Saint-Petersburg distr., Russia
Контактная информация:

Re: Halcompail и драйвер.

Сообщение Nick »

Lexxa писал(а):Почему ни НН320 (3мс), ни НН620 (3мс) ни ННi530 (3 мс, опционально 0.1), ни sinumerik 828 (3 мс интерполятор/125мкс серво) такие короткие времена тактов не нужны.
Что будет если у линукс цнц такт по положению сделать тоже 3 мс?
Lexxa писал(а):UAVpilot,
Ну так скажи что урезать, я попробую, ибо это надо.
GUI нужен? Или можно без него?

PS может с этим в отдельную тему?
T00T
Мастер
Сообщения: 742
Зарегистрирован: 16 дек 2011, 12:07
Репутация: 100
Контактная информация:

Re: Halcompail и драйвер.

Сообщение T00T »

Nick писал(а):PS может с этим в отдельную тему?
Я б так вообще последнюю страницу всю в другую тему. Но визуализация в AXIS вещь неоценимая, снижает уровень ошибок до нуля!!!
Nick писал(а):Сам servo-period плавает. Но в определенных пределах. При этом мы знаем на сколько уплыл текущий период.
Т.е. погрешность будет только в пределах 1-2 периодов. Что при этом имеем:
1. Запросим у FPGA инфу на +-25мкс раньше
2. Все рассчеты будут начинаться +-25мкс.
3. Отправим команду в FPGA на +-25мкс раньше

Далее, у FPGA период не плавает.
Вот это походу относиться к данной теме. Я думаю что ещё проще, а именно: ЧПУ выставляет грубо говоря для каждого серво-цикла новое положение, и я думаю расчёт этого положения ведётся с учётом того, что серво-цикл 1мс, а какой он там реально будет 1025 мкс или 990 мкс не важно, он в среднем как ты говоришь и будет 1000 мкс, поэтому для FPGA вообще всё это лишнее. Просто при расчёте частоты степа нужно исходить из этих соображений.
Ну эксперементы покажут.
Я не волшебник я пока учусь......
Аватара пользователя
Nick
Мастер
Сообщения: 22776
Зарегистрирован: 23 ноя 2009, 16:45
Репутация: 1735
Заслуга: Developer
Откуда: Gatchina, Saint-Petersburg distr., Russia
Контактная информация:

Re: Что можно урезать в Linux/LinuxCNC, чтобы сделать меньше

Сообщение Nick »

Раз уж тема новая, давайте рассуждать с чего начинать урезать :).

Я так понимаб для начала надо посмотреть lsmod. Lexxa, что он у тебя показывает?
Аватара пользователя
Serg
Мастер
Сообщения: 21923
Зарегистрирован: 17 апр 2012, 14:58
Репутация: 5183
Заслуга: c781c134843e0c1a3de9
Настоящее имя: Сергей
Откуда: Москва
Контактная информация:

Re: Что можно урезать в Linux/LinuxCNC, чтобы сделать меньше

Сообщение Serg »

Если хотите "урезать Linux", то в первую очередь надо определится с составом и конфигурацией железа (проц, чипсет и т.п.).
Я не Христос, рыбу не раздаю, но могу научить, как сделать удочку...
Ответить

Вернуться в «LinuxCNC»