Lego mindstorms linux ev3
So you’re ready to try out ev3dev. Great! Here are step-by-step instructions to help you get ev3dev up and running on your EV3 or Raspberry Pi.
First, here are the things you need before starting:
- A LEGO MINDSTORMS EV3 Intelligent Brick or Raspberry Pi (any model).
- A microSD or microSDHC card (2GB or larger). microSDXC is not supported on the EV3. All cards larger than 32GB will not work with the EV3!
- A computer with an adapter for the SD card. You will need administrator user permissions on this computer.
A way to communicate with the device.
For the EV3, this can be one of the following:
- USB cable (the one that comes with the EV3)
- USB Wi-Fi dongle
- USB Ethernet (wired) dongle
- Bluetooth
For Raspberry Pi you can use a wired Ethernet connection first. With PiStorms the EV3 options will work too since you have a built-in screen to configure them on. With BrickPi you can also set up other connections from the console using an external screen and keyboard.
Step 1: Download the latest ev3dev image file
Other platforms
To get started, you will need to download the release corresponding to the platform you are using. For additional downloads and advanced information, check out our dedicated download page.
To get started, you will need to download the release corresponding to the platform you are using. Visit the GitHub releases page and find the image that corresponds to your platform:
- Releases for the LEGO MINDSTORMS EV3 start with ev3-
- Releases for the Raspberry Pi 1 start with rpi-
- Releases for the Raspberry Pi 2 and 3 start with rpi2-
- Releases for the BeagleBone start with evb-
Step 2: Flash the SD card
This will erase everything on your SD card! Back up your files if you do not want to lose them!
Now it’s time to write the image to the card.
Launch Etcher after it has finished installing.
Etcher home screen
Click the “Select image” button and browse to the folder where you downloaded an ev3dev release. Select the file that you downloaded. The release can be a .img.zip or .img.xz ; whichever you have will work with Etcher.
Image chosen in Etcher
Plug the SD card into your PC (if your PC doesn’t have a micro SD slot, you can use an adapter or external reader). Etcher should detect the new device and display its information under the “Select drive” step. Confirm that the selected drive is correct.
Drive selected in Etcher
If you have multiple removable drives available, you may need to use the “Change” button to select the proper device.
When you are confident that you have selected the correct drive, click “Flash!” and wait for the operation to complete.
Etcher flashing the SD card
If you arrive at this screen, you have successfully flashed your SD card and are ready to move on to the next step.
Etcher success screen
For more detailed information and flashing utility alternatives, check out our other tutorials. You can also check out this page for RaspberryPi. Much of the information there is applicable to ev3dev.
Step 3A (Raspberry Pi only): Update options in config.txt
This is for Raspberry Pi only! Users of other platforms can skip this step.
You must make some changes to config.txt to enable support for BrickPi or PiStorms before you put your SD card in your Raspberry Pi.
You may have to remove the SD card from your host computer and plug it back in after flashing it in order for it to be detected. In your file browser, open up EV3DEV_BOOT . This contains a file named config.txt . Open config.txt in your favorite text editor and follow the instructions in the file to enable either BrickPi or PiStorms.
Step 3B (BeagleBone only): Select cape in uEnv.txt
This is for Beaglebone only! Users of other platforms can skip this step.
You must make some changes to uEnv.txt to enable support for FatcatLab EVB or QuestCape before you put your SD card in your BeagleBone.
You may have to remove the SD card from your host computer and plug it back in after flashing it in order for it to be detected. In your file browser, open up EV3DEV_BOOT . This contains a file named uEnv.txt . Open uEnv.txt in your favorite text editor and follow the instructions in the file to select the cape your are using.
Step 4: Boot ev3dev
Put the SD Card in your EV3 and power it on. At first, you will see the MINDSTORMS boot splash and the red LEDs will be on. This is immediately followed by the ev3dev boot splash and the LEDs changing to orange. The LEDs indicate disk (SD card) activity.
After about one minute, the screen will go blank. This happens on the first boot only. The first boot takes longer than subsequent boots because the EV3 has to create a unique SSH host ids and take care of a few other housekeeping items. After another minute or two, you will see the brickman loading… screen. If nothing has happened after five minutes, something is not right - check the troubleshooting tips below.
You will notice the number in the battery in the upper right corner. This displays the remaining voltage of the power supply. It is not possible to calculate an accurate percent value of the remaining energy, so this value is chosen. If the voltage drops below 5V the brick will turn off. All unsaved data will be lost. Keep in mind, that it may take a much longer time from 8V to 6.5V than from 6.5V down to 5V!
Note: If you are using Raspberry Pi hardware without a screen, just wait for the Activity LED to stop flashing, then go to the next step. If alternatively you have connected the pi to a screen monitor via HDMI press Ctrl + Alt + F6 at the end of the boot sequence. This should take you to a login prompt. Login as ‘robot’ with password ‘maker’.
When the boot is complete, the LEDs will turn green and you will see something like this on the screen
- Make sure nothing is plugged into the EV3 (USB/sensors/motors/etc.)
- Try writing the image to the SD card again.
- You may have a bad/incompatible SD card - try a different SD card.
- Check the condition of the EV3 batteries.
Shutting down
You’ll often want to turn off your EV3 while it isn’t in use. When you are ready to wish your EV3 good night, turn if off by pressing the back button from the main menu in brickman or pressing and holding the back button from any screen in brickman. This will open a dialog where you can select Power Off to turn off the EV3. If you’re using the command line, running sudo poweroff in a terminal works too.
The 'Shutdown. ' dialog in Brickman
Step 5: Set up a network connection
Click on the button below to visit our networking page. There are lots of choices here; choose the connection option that best suits you and your available hardware.
Step 6: Connect to the EV3 via SSH
Now that you have a network connection, you should connect to your EV3 with SSH. Connecting allows you to verify that the networking option that you configured in the previous step is working. Once you have an SSH connection, you will be able to securely run terminal commands on the EV3 from your PC. This lets you run programs, change settings, and install new programs. Click the button below to learn how to connect.
To test this out, let’s try running a command (make sure that you have completed the earlier part of this step first).
Type the command fortune into the SSH shell opened above and press Enter . It will use a nifty program called fortune to print out a random quote from a database. Feel free to try it multiple times!
If you don’t see any errors printed, and your output looks similar to the above, you’re good to go!
Step 7: Choose a programming language and write some code
If you were sent here from a language- or framework-specific webpage, you can skip this step and return there for further instructions.
The brick can run the vast majority of popular programming languages, so your favorite language is probably supported. Pick your language and write some code!
LEGO® is a trademark of the LEGO Group of companies which does not sponsor, authorize or endorse this site
Несмешной и баянистый анекдот, но нельзя просто так взять и начать эту публикацию не с него – он в лучшем виде отображает суть того, о чём пойдёт речь далее. Впрочем, из заголовка вы и так поняли, о чём речь.
Осторожно! Публикация может вызвать непреодолимое желание завести сына.
Урок истории
Компания LEGO (название произошло от датской фразы «leg godt», «Играй с удовольствием») не нуждается в представлении – она была основана в далёком 1932 году, хотя первые знакомые всем пластиковые кубики появились значительно позже, в 1947. Примечательно, что кубики LEGO, выпускаемые в те годы, полностью совместимы с теми, что выпускаются сейчас.
История создания компании, выпущенная компанией Pixar к 80-летнему юбилею LEGO:
Сейчас компания производит около 20 миллиардов деталек в год, то есть более 630 штук в секунду. В текущем модельном ряду более 600 различных конструкторов и так уж получилось, что серия Mindstorms является своего рода вершиной технической мысли, самым-самым навороченным конструктором. Если вкратце, то она позволяет делать вполне себе полноценных роботов.
Как гласит википедия, серия LEGO Mindstorms была впервые представлена в 1998 году. Через 8 лет (в 2006) на свет появился набор LEGO Mindstorms NXT 1.0, а уже в 2009 — набор LEGO Mindstorms NXT 2.0. Сегодня речь пойдёт о LEGO Mindstorms EV3 – последнем (третьем) поколении терминатора конструктора, который был представлен почти год назад, 4 января 2013 года (в продаже появился только спустя полгода).
Отличия EV3 от NXT 2.0
В принципе, главная идея осталась прежней – серия предназначена для сборки программируемых роботов. Поэтому первым встаёт вопрос, а что же поменялось с момента выхода предыдущего конструктора и стоит ли покупать новый? Основное отличие заключается в обновленных датчиках/моторах и, самое главное, в интеллектуальном блоке EV3 (EV означает EVolution):
EV3 | NXT | |
Дисплей | Монохромный LCD, 178x128 | Монохромный LCD, 100x64 |
Процессор | 300 МГц Texas Instruments Sitara AM1808 (ARM9) | 48 МГц Atmel AT91SAM7S256 (ARM7TDMI) |
Память | 64 Мб RAM 16 Мб Flash Слот microSDHC (до 32 Гб) | 64 Кб RAM 256 Кб Flash |
USB-хост | Есть | Нет |
Wi-Fi | Опционально, через USB-донгл | Нет |
Bluetooth | Есть | Есть |
Поддержка Apple-устройств | Есть | Нет |
Ещё одно отличие заключается в том, что серия NXT продавалась в нескольких версиях (в разные годы) и представляла собой разные наборы, базовые и ресурсные. У нового EV3 с этим попроще – пока он продаётся в основном варианте – 31313 (601 деталь), из которого можно наделать кучу всего. Но при желании можно докупить базовый набор 45544 (541 деталь) с дополнительными сенсорами и детальками (использовать детали от обычных конструкторов также никто не мешает). Кстати, обратите внимание на пятизначные артикулы – на такую нумерацию компания перешла в 2013 году.
Что касается совместимости, то тут было проделано всё возможное. Все NXT-сенсоры и моторы совместимы с EV3 и распознаются как NXT. EV3-сенсоры не работают с NXT, но EV3-моторы вроде как совместимы. NXT-кирпичик может быть запрограммирован софтом от EV3, но некоторые функции могут быть недоступны, а вот запрограммировать EV3-кирпичик NXT-софтом без сторонних решений не получится.
Внутри коробки
Ещё когда я сам был маленький и ездил с родителями в центральный Детский Мир (когда он ещё был), на Лубянку – уже тогда я не мог оторвать глаз от коробок с LEGO. Тогда не было ни Гиктаймс, ни даже Хабра, но с тех пор коробки остались всё такими же яркими и сочными, даже во взрослом возрасте активируют процесс слюновыделения ) В этом плане другим производителям есть чему поучиться.
Часть коробки, на самом деле, представляет собой (если её разрезать) трассу с различными цветовыми зонами, которую можно использовать для роботов с сенсорами цвета.
Все детальки аккуратно разложены по пакетикам, в комплекте – инструкция и набор наклеек. Давайте вкратце пройдёмся по тому, что положили в комплект.
Сам EV3, он же интеллектуальный блок, он же сердце системы, он же «кирпичик» или «кубик». Служит центром управления и энергетической станцией для вашего робота и имеет следующие функциональные элементы:
– Многофункциональный монохромный дисплей с разрешением 178х128
– Шестикнопочный интерфейс управления с функцией изменения подсветки (3 цвета) для индикации режима работы
– 4 порта ввода (1, 2, 3, 4) для подключения датчиков
– 4 порта вывода (A, B, C, D) для выполнения команд
– 1 разъём miniUSB для подключения EV3 к компьютеру
– 1 порт USB–хост (для соединения нескольких EV3 в одну цепь, например)
– 1 слот для карт памяти формата microSD (до 32Гб) – для увеличения объёма доступной памяти EV3
– Встроенный динамик
Кубик EV3 также поддерживает Bluetooth, WiFi (через USB-адаптер NETGEAR WNA1100 Wireless-N 150), для связи с компьютерами имеет программный интерфейс, позволяющий создавать программы и настраивать регистрации данных непосредственно на микрокомпьютере EV3.
» Большой EV3-сервомотор (2 штуки). Cоздан для работы с микрокомпьютером EV3 и имеет встроенный датчик вращения с точностью измерений до 1 градуса. Используя этот датчик, мотор может соединяться другими моторами, позволяя роботу двигаться с постоянной скоростью. Кроме того, датчик вращения может использоваться и при проведении различных экспериментов для точного считывания данных о расстоянии и скорости.
– Встроенный датчик вращения с точностью измерений до 1 град
– Максимальные обороты до 160-170 об/мин
– Максимальный крутящий момент в 40 Нсм
– Автоматическая идентификация программным обеспечением EV3
» Средний EV3-сервомотор. Идеален для задач, когда скорость и быстрота отклика, а также размер робота важнее его грузоподъёмности.
– Встроенный датчик вращения с точностью измерений до 1 градуса
– Максимальные обороты до 240-250 об/мин
– Максимальный крутящий момент в 12 Нсм
– Автоматическая идентификация программным обеспечением EV3
» Датчик цвета (EV3). Способен определить 8 различных цветов, хотя также может использоваться как датчик освещённости.
– Измеряет отраженный красный свет и внешнее рассеянное освещение, от полной темноты до яркого солнечного света
– Фиксирует и определяет 8 цветов
– Частота опроса до 1 кГц
– Автоматическая идентификация программным обеспечением EV3
» Датчик касания (EV3). Позволяет роботу реагировать на касания, распознает три ситуации: прикосновение, щелчок и освобождение. Также способен определить количество нажатий, как одиночных, так и множественных.
» Цифровой ИК-датчик (EV3). Для определения приближения робота. Также способен улавливать ИК-сигналы от ИК-маяка, позволяя создавать дистанционно управляемых роботов, навигационные системы для преодоления препятствий.
– Измерения приближения/удаления в радиусе 50-70 см
– Радиус улавливания ИК-сигналов до 2 метров
– До 4 индивидуальных каналов приёма сигнала
– Получение удаленных ИК-команд управления
– Автоматическая идентификация программным обеспечением EV3
» Удалённый инфракрасный маяк. Разработан для использования с ИК-датчиком EV3. Маяк излучает ИК-сигнал, улавливаемый датчиком – может использоваться в качестве пульта дистанционного управления микрокомпьютера EV3, передавая сигналы на ИК-датчик.
– До 4 индивидуальных каналов передачи сигнала (переключатель прямо на корпусе)
– Имеет кнопку и тумблер для включения/выключения
– При работе ИК-маяка горит зелёный светодиод
– Автоматическое отключение при простое более 1 часа
– Радиус действия до 2 метров
В отдельном пакетике смотаны провода для подключения датчиков и моторов к кубику, а также USB-шнур для подключения кубика к компьютеру.
Стоит отметить два важных момента. Во-первых, существуют другие датчики Lego, такие как:
» Гироскопический датчик (EV3). Цифровой гироскопический датчик EV3 позволяет измерять движение вращения робота, а также улавливать изменения в его движении и положении. Режим измерения углов с точностью до ± 3 градуса; встроенный гироскоп улавливает вращения с моментом до 440 град/с; частота опроса до 1 кГц.
» Ультразвуковой датчик (EV3). Генерирует звуковые волны и фиксируюет их отражения от объектов, тем самым измеряя расстояние до объектов. Также может использоваться в режиме сонара, испуская одиночные волны. Может улавливать звуковые волны, которые будут являться триггерами для запуска программ. Измеряет расстояния в пределах от 1 до 250 см, а точность измерений составляет ± 1 см.
А во-вторых, поддерживаются сенсоры и прочие аксессуары от сторонних производителей, таких как HiTechnic и Mindsensors – они предлагают всевозможные джойстики, инфракрасные датчики расстояний, магнитные датчики, компасы, гироскопы, акселерометры, таймеры, мультиплексоры, шаровые опоры, и т.д. Так что, если задаться вопросом, можно найти много всего интересного.
В общем, как вы уже поняли, LEGO – это для реальных пацанов!
Первая модель
В комплекте с конструктором идёт бумажная инструкция, по которой можно собрать одну-единственную модель – некое подобие гусеничной самоходной машины.
Сначала я удивился, ведь даже в самых простых наборах (серии типа LEGO Creator) всегда идёт несколько инструкций, а тут вдруг бумаги пожалели или места в коробке не нашли. Оказалось… что только на официальном сайте из набора деталей предлагается собрать 17 разных роботов! Поэтому 17 инструкций в коробке были бы действительно лишними (и для логистики, и для лесов природы). Вот названия роботов: EV3RSTORM, GRIPP3R, R3PTAR, SPIK3R, and TRACK3R. ROBODOZ3R, BANNER PRINT3R, EV3MEG, BOBB3, MR-B3AM, RAC3 TRUCK, KRAZ3, EV3D4, EL3CTRIC GUITAR, DINOR3X, WACK3M, и EV3GAME – инструкции для них придётся качать из инета, равно как и софт для подключения EV3 к компьютеру.
Инструкция наиподробнейшая, накосячить сложно. Сын сказал , что детали в пакетиках расфасованы не очень удачно – на первой же странице может потребоваться вскрыть 3 разных пакета, но это тоже мелочи.
Кубик EV3 необходимо запитать, для чего можно использовать аккумулятор (нет в комплекте) или 6 пальчиковых батареек. Забегая вперёд – ещё 2 батарейки (но уже мизинчиковых) понадобятся для питания ИК-маяка (он же пульт ДУ).
Первую модель ребёнок (7 лет) собрал примерно минут за 30.
Процесс оказался не таким увлекательным, как, например, сборка моделей LEGO Technics – в инструкции предлагается собрать далеко не самого интересного робота: в нём лишь крупные детали, среди которых были практически все датчики и двигатели – видимо, чтобы продемонстрировать работу каждого из них.
Но вот результат превзошёл все детские ожидания – впервые он собрал модель, которая могла двигаться сама: вперёд-назад, поворот, разворот на месте, крутила щупальцами…
Запуск осуществляется с кубика EV3, для чего следует нажать пару кнопок на лицевой панели. Некоторые действия можно запрограммировать прямо на кубике: выбрать количество итераций, настроить подачу звукового сигнала и так далее – в одной статье всего не рассказать, курите мануалы.
Программировать через компьютер собранную выше модель не пришлось. Тем не менее, возможность такая есть, при этом на разных уровнях хардкорности.
Ребёнку проще всего будет начать с предлагаемого производителем софта, который есть как под Windows, так и под OS X. Во втором случае дистрибутив весит 666 Мб, а установленное приложение займёт гигабайт. Оно называется LEGO Mindstorms EV3 Home Edition и разработано совместно с небезызвестной компанией LabView. На сайте LEGO довольно много обучающих программированию материалов.
Сразу после запуска перед нами возникает интерактивный «гараж» из роботов, которых можно собрать из набора:
Выбираем понравившегося и начинаем собирать: перед нами появится интерактивная инструкция по сборке, видеоролики, а также подборка различных миссий, которые можно выполнить с собранным роботом. Вот почему дистрибутив весил так много.
Не вижу смысла описывать всё в деталях: вы быстрее скачаете приложение сами и увидите, что там есть и на каком уровне. Разве что упомяну один из недостатков, который мне больше всего запомнился: не самый дружелюбный (особенно для детей) интерфейс – от приложения попахивает каким–то банк-клиентом.
Нельзя ещё раз не отметить, что кубиком EV3 можно управлять со смартфона на операционных системах Android или iOS, для чего есть отдельные приложения.
Если всего этого оказалось мало, можете повысить градус хардкора. Для кубика EV3 существуют различные прошивки, которые позволяют расширить его возможности, скорость работы и т.д. Вот, например, альтернативная прошивка leJOS EV3 – прошивка с jvm, позволяющая программировать EV3 на языке Java. Хотите на другом языке? Окей, гугл – в вашем распоряжении почти 60 вариантов на выбор: ASM/C/C++/Perl/Python/Ruby/VB/Haskell/Lisp/Matlab/LabVIEW и многое-многое другое.
Более подробно об этом я рассказывать не буду по нескольким причинам: во-первых, программист из меня полный false (все надежды на сына), во-вторых, пока мы успели собрать только одну модель (и на выходных возьмёмся за вторую), а в-третьих – вы уже и так оформили заказ на этот конструктор и скоро сами всё узнаете ;) Ну а если серьёзно, то статья и так уже огромная – вот лучше две ссылочки изучите: раз и два.
Ну и ещё большой плюс – это LEGO-сообщества, которых полно по всему миру. Можете быть уверены, что на любом из этапов экспериментов с роботами вы всегда сможете найти единомышленников и тех, кто сможет помочь с решением проблемы. Помимо дружелюбных сообществ, на просторах сети выложено огромное множество различных инструкций, моделей, исходников, видеороликов и обучающих материалов. Всё это означает одно: с Mindstorms вы не соскучитесь.
Здесь публикуются заметки о том, как заменить Windows и использовать бесплатное ПО для программирования роботов.
среда, 18 июля 2018 г.
Программирование Lego EV3 на Python. Настройка Eclipse под Linux
В этой статье мы установим и настроим Eclipse для программирования блока Lego EV3 с прошивкой ev3dev на языке Python. Настроенный Eclipse не только будет поддерживать автодополнение кода и подсвечивать синтаксис, но и позволит его отлаживать. В том числе будет доступно наблюдение за изменением переменных во время выполнения роботом своей программы.
Показать/Скрыть 1. Требования к подготовке
1. Терпение. Статья длинная, но она того стоит!
3. Соединение блока с компьютером по USB-проводу или с помощью сети Wi-Fi (для этого понадобится Wi-Fi-адаптер, я проверил TP-Link 725 v2 и TP-Link 723, точно подойдут NetGear 1100 и Edimax 7811Un — но их найти, как говорится, днём с огнём …)
Замечание. Соединение через Wi-Fi потребует использование роутера, именно через него, т. е. через общую сеть, будет соединение с компьютером. Но здесь плюсом будет, то, что если на роутере есть интернет, то интернет будет доступен и на EV3 блоке. Это означает, что получив к нему удаленный доступ с компьютера (например, по SSH протоколу) вы можете устанавливать на нём программы прямо из репозитория linux (но обязательно в начале нужно будет обновить список
Из минусов: мощность EV3-блока завораживает (шутка!), поэтому установка программ будет долгой, очень долгой (у меня пакет весом 180 МБ устанавливался полтора часа). По этой же причине лучше не делать sudo apt upgrade, т. к. для обновления всей системы ev3dev проще заново записать образ на SD карту.
Логика установки
Мы установим IDE Eclipse, настроим в нём пути к интерпретатору, исходникам библиотеки, соединение с блоком EV3 по протоколу SSH, вывод автодополнений и др.
Замечание: кроме Eclipse ещё тестировался редактор nxcEditor, который прекрасно программирует блоки NXT, но стабильного соединения по SSH от него к блоку EV3 получить не удалось, а в интернете информации про это не нашлось.
Важные моменты
Ниже представлен только мой опыт, он не претендует на полноту и правильность. Это только то, что оказалось достаточным в моём случае. Но, надеюсь, что он окажется полезным.
Показать/Скрыть 2. Тестирование Python и SSH
Прошивка на SD-карте — ev3dev — основана на linux-дистрибутиве debian. Т.е. Python там стоит по умолчанию. Установим с EV3-блоком ssh-соединение и запустим простейший скрипт для тестирования интерпретора и библиотеки ev3dev.ev3.
Альтернативно вместо ev3dev.local можете использовать ip-адрес EV3-блока, его можно посмотреть на экране блока. Например, ssh robot:[email protected]
Показать/Скрыть 3. Установка Eclipse
Далее используется версия программы Eclipse Photon (Eclipse IDE for Java EE Developers).
Показать/Скрыть 4. Настройка Eclipse для Python
2. При запуске программа запросит нахождение рабочей папки, т. к. у нас будет использовать только Python, то нажмите кнопку Browse… и выберите папку ~/ev3dev-Python/
Если вы будете работать только в этой рабочей папке, то можно поставить галочку Use this as the default and do not ask again.
Показать/Скрыть 5. Установка PyDev
1. Устанавливаем плагин PyDev (чтобы можно было программировать на Python). Для этого выбираем Help → Eclipse Marketplace …
4. Соглашаемся с лицензиями, выбрав I accept the terms of the license agreements и нажав кнопку Finish.
7. После перезапуска проверьте установку PyDev. Для этого откройте меню Window → Preferences и слева в списке найдите пункт PyDev. Если пункт есть, значит установка прошла успешна, заодно вы можете посмотреть версию плагина. Закройте это окно.
Показать/Скрыть 6. Настройка интерпретатора в PyDev
4. Откройте меню Window → Preferences, разверните в списке слева PyDev → Interpreters → Python Interpreter
Показать/Скрыть 7. Установка библиотеки JCraft
Далее, устанавливаем библиотеку JCraft для автоматической синхронизации редактируемого файла с его копией на EV3-блоке. Т.е. файл проекта сохраняется на компьютере в рабочей папке ev3dev-Python и при любых изменения моментально будет загружаться и обновляться на EV3-блоке.
1. Скачайте с официального сайта библиотеку JCraft (ищите в разделе Download файл jsch-0.1.54.jar или более позднюю версию) или скачайте её по ссылке:
у меня нашлась директория org.apache.ant_1.10.3.v20180417-1627
4. Зайдите во вложенную в неё папку lib
5. Скопируйте сюда скачанную ранее библиотеку JCraft. Например, если библиотека находится в стандартной папке Загрузки, то наберите
6. Теперь откройте настройки Eclipse (меню Windows → Preference). откройте Ant → Runtime, выберите Ant Home Entries (Default) на закладке Classpath и нажмите кнопку Add External JARs. .
Но т.к. .p2 — скрытая папка, она отображаться не будет. Чтобы она стала доступна, щёлкните правой кнопной мыши на свободно месте и поставьте с появившемся контекстной меню галочку Show hide files
9. После этого JCraft появится в списке файлов библиотек. Нажмите Apply and Close, чтобы сохранить изменения.
Показать/Скрыть 8. Добавление шаблона программы Python для EV3
Каждый файл проекта на Python для EV3 должен начинаться с определённых строк. Для удобства добавим шаблон для нового файла.
1. Откройте настройки Window → Preferences, найдите слева в списке PyDev → Editor → Templates и нажмите кнопку New…
2. В появившемся окне уберите галочку Automatically insert, в списке Context — New Module. В поле Name напишите EV3
Показать/Скрыть 9. Создание нового проекта PyDev
5. Теперь на панели PyDev Package Explorer появилась папка с вашим проектом. Обратите внимание на ссылку на интерпретатор Python3.
Показать/Скрыть 10. Добавление в проект ссылок на исходники библиотек ev3dev.ev3 и Python
Чтобы Eclipse при работе с классами библиотек ev3dev.ev3 и Python выдавал подсказки и делал автодополнение добавим в проект ссылки на исходники этих библиотек.
2. Чтобы скачать исходники ev3dev.ev3 с сайта github, удобно пользоваться утилитой git, установите её
3. Далее добавим в проект Eclipse ссылку на скачанную библиотеку. Для этого щёлкните правой кнопкой мыши по названию проекта и выберите пункт Properties
4. В окне свойств проекта выберите в списке слева PyDev — PYTHONPATH. Далее выберите вкладку External Libraries и нажмите на кнопку Add source folder.
7. Далее чтобы добавить путь к исходникам PyDev, смотрим версию установленной библиотеки. Меню Window → Preference и в списке слева щёлкаем по пункту PyDev и запоминаем версию
8. Далее также как и ранее заходим в свойства проекта (Properties), выбираем PyDev — PYTHONPATH нажимаем Add source folder ещё раз, чтобы добавим путь к исходникам библиотеки PyDev (добавляете всю папку pysrc, у меня ~/.p2/pool/plugins/org.python.pydev.core_6.4.3.201807050139/pysrc).
Показать/Скрыть 11. Добавление модуля Python в проект
Создадим маленький проект, в котором EV3-блок будет говорить фразу Welcome to the E V 3 project как в начале статьи, но уже с помощью Eclipse, с поддержкой автодополнения и проверки синтаксиса.
4. Во втором окне показаны некоторые настройки Python, которые можно сейчас изменить. Не изменяйте их. Просто нажмите OK.
5. Наконец-то, мы видим свой созданный модуль first_module.py, при этом он уже содержит ранее созданный шаблон.
6. Предупреждение на второй строке означает, что мы сделали импорт модулей, которые не используем. Мы импортируем все модули звёздочкой … import *. Игнорируем это замечание.
9. Если вы щёлкните по подсказке, появится полоса прокрутки, можно просмотреть всю справку, выделить и скопировать нужные участки кода.
Обратите внимание, что пока в строке не правильный синтаксис в её начале будет красный крестик.
10. Теперь поставьте точку после слова Sound. Eclipse покажет доступные методы и атрибуты класса Sound. По списку можно передвигаться клавишами-стрелками и выбирать нужный клавишей Enter.
12. Добавьте метод wait(). Наша программа готова. Чтобы сохранить изменения в текущем файле, нажмите комбинацию Ctrl + S — звёздочка слева от имени файла исчезнет. (А чтобы сохранить все изменения в проекте нужно нажать комбинацию Ctrl + Shift + S).
На выполненном проекте мы увидели как работает автодополнение, подсказки, подсветка кода и проверка синтаксиса.
Показать/Скрыть 12. Автоматическое копирование файлов программ Python на EV3
Настроим Eclipse так, чтобы текущий проект автоматически копировался на EV3-блок и автоматически там обновлялся при каждом его сохранении на компьютере. Воспользуемся для этого библиотеками Ant и JCraft.
1. Создайте файл build.xml. Для этого щёлкните правой кнопкой мыши по названию проекта и выберете New → File
Файл «build.xml» в Eclipse по умолчанию ассоциируется с библиотекой Ant. В этом файле описываются действия, которые должна выполнить библиотека Ant. В нашем случае здесь описано, откуда нужно взять файлы и куда их нужно скопировать. Я не буду сильно углубляться в описание того, как работает библиотека Ant и как её нужно настраивать с помощью файла «build.xml», но опишу то, что используется в этом файле. Вы можете использовать этот файл, как образец.
Первый элемент «project» (проект) - это обязательный корневой элемент файла «build.xml». В атрибуте «name» указывается имя проекта. Я указал здесь «ev3sync».
Дальше идёт элемент «target» - это цель. Целей в проекте может быть несколько. В атрибуте «name» указывается имя цели. В моём примере это тоже «ev3sync».
Внутри цели указываются задачи, которые нужно выполнить для достижения этой цели. Здесь у нас только одна задача, которая выполняется библиотекой JCraft – это элемент «scp». Эта задача как раз и выполнит копирование всех файлов Python и папки проекта на EV3. Здесь в атрибуте «todir» указана папка назначения в формате «user[:password]@host:/dir/path», т.е. сначала идёт имя пользователя (у нас это «robot»), затем через двоеточие пароль (у нас это «maker»), затем после собачки имя или IP-адрес EV3 (у нас это «ev3dev»), затем после двоеточия путь (у нас это директория «/home/robot»). В атрибутах «dirmode» и «filemode» указываются, какие атрибуты нужно выставить созданным папкам и файлам. Обратите внимание, что для уже созданных файлов атрибуты не поменяются.
Внутри элемента «scp» с помощью элемента «fileset» указывается набор файлов, которые нужно скопировать на EV3. В атрибуте «dir» указывается папка, где находится набор файлов. Здесь у нас указана точка, это значит, что такой папкой будет папка проекта. С помощью атрибута «casesensitive» я указал, что в именах файлов регистр не важен.
Внутри элемента «fileset» с помощью элемента «include» указываются файлы, которые должны быть включены в набор файлов. Здесь с помощью атрибута «name» я указал, что в набор файлов входят все файлы с расширением «.py», в том числе находящиеся и в подпапках. В качестве примера я добавил элемент «exclude», с помощью которого можно указать, какие файлы не должны входить в набор файлов. Здесь с помощью атрибута «name» я указал, что в набор файлов не входят файлы, в имени которых есть слово «Test», в том числе и в подпапках.
В итоге мы получили задание с названием «ev3sync», которое будет копировать все файлы проекта с расширением «.py» в имени которых нет слова «Test» на EV3 в папку «/home/robot».
От себя добавил пункт trust="true", без него не происходило соединение и изменил хост на ev3dev.local (было ev3dev).
6. В окне Edit Configuration перейдите на вкладку Main и для Buildfile нажмите кнопку Browse Workspace.
13. Снизу окна Eclipse появилась вкладка Colsole, в которой будет написано, что файл build.xml построен успешно.
14. Теперь переключитесь на вкладку first_module.py, в любом месте поставьте и сотрите пробел, нажмите сохранение Ctrl + S. В панели Colsole показано, что произошло подключение к блоку EV3 и задание успешно выполнилось. Теперь каждое сохранение файла в Eсlipse будет обновлять копию этого файла в EV3-блоке.
Показать/Скрыть 13. Запуск программы на EV3
Программы на Python'е будем запускать через встроенный терминал Eclipse. Он позволит получить доступ к файловой системе EV3-блока, запускать и останавливать программы, в том числе принудительно, а в случае необходимости и удалять их.
В терминале мы уже работали, когда в начале статьи тестировали соединение SSH и язык Python. Теперь настроим SSH для встроенного терминала Eclipse.
1. Подключите к компьютеру EV3-блок (по USB или Wi-Fi).
2. Запустите Launch Terminal, нажав на соответствующую кнопку или комбинацией клавиш Ctrl + Alt + Shift + T.
3. Заполните поля настроек терминала.
Choose terminal — SSH Terminal
Host — обычно ev3dev.local или его ip-адрес, например, 10.42.0.3
User/Password — robot/maker
Encoding — UTF-8
Галочки на пунктах Save user и Save password
После настройки SSH у меня возникла интересная особенность: история команд отображалась, а сама строка ввода не пропечатывалась (возможно у вас такого не будет). Чтобы это решить можно развернуть вкладку Terminal (делается двойным щелчком по названию вкладки)
и таким же образом свернуть эту вкладку. Прокрутите полосу прокрутки до самого низа и сравните — появилась надпись robot@ev3dev:~$
Она уже скопирована в папку /home/robot/ EV3-блока, т. е. в домашней директории ~. Terminal уже открыт в этой папке. Для запуска напечатайте
Здесь публикуются заметки о том, как заменить Windows и использовать бесплатное ПО для программирования роботов.
суббота, 30 июня 2018 г.
Программирование на EV3-G под Linux
Особенности:
2 Запуск будет проводится с помощью программы wine (она позволяет запускать windows-приложения — в основном 32-битные — на linux). Функционал Lego EV3 будет полностью работать, за исключением работы с EV3-блоком по USB и Bluetooth.
3 У программы wine есть проблемы взаимодейтсвия с USB-устройствами. Несмотря на то, что подключение флешек она видит, мой EV3-блок она так и не увидела (на вышеупомянутом официальном сайте wine также описана эта проблема). Поэтому взаимодействовать по USB-проводу с EV3-блоком не получится, как и по Bluetooth (( Только по Wi-Fi, но и здесь есть нюансы:
3.1 В EV 3-блоке нет Wi-Fi карточки, поэтому нужно использовать USB -свисток. Но стандартная прошивка EV 3-блока (на момент написания, это 1.09H для домашней версии, 1.09E — для образовательной и 1.09D — для разработчиков: все практически идентичны) поддерживает только два вида Wi-Fi свистков: NetGear N150 (WNA1100) и EdiMax EW-7811UN . Если вы захотите их приобрести, то я рекомендую последний за его компактность. В продаже они редко встречаются, но можно найти в online-магазинах.
Замечание. Такой острой проблемы поддержки Wi-Fi-адаптеров нет в альтернативных прошивках, см. статьи «Сборка собственной прошивки из исходников» (ссылка ожидается) и «Программирование на Python» (ссылка ожидается).
3.2 Чтобы получить соединение между компьютером и EV3-блоком оба должны быть подключены к общей сети Wi-Fi, т. е. вам ещё и роутер нужен. Я использовал свой домашний роутер, который раздаёт интернет.
Далее ориентируюсь на статью. Там дана последовательность установки без объяснения, я разделил её на шаги и подписал назначение каждого из них.
Совет. Команды можно не перепечатывать, а копировать и вставлять в терминал (комбинации Ctrl + Insert / Shift + Insert)
Удаление ранее установленного wine
Если wine у вас уже установлен можете попробовать пропустить шаги для удаления, но я всё же рекомендую удалить wine:
1. sudo apt purge wine winetricks (удаляем утилиту для работы с wine и сам wine - нужно будет ввести пароль)
4. rm -rf ~/.wine (удаляем всю скрытую папку .wine с установленными ранее программами, из того места, где они были установлены, показан пример для удаления из домашней папки «~/» — у вас может отличаться)
Установка wine и winetricks
1. Стандартная установка нам не подойдёт, потому что в стандартном репозитории хранится старая версия wine.
Здесь публикуются заметки о том, как заменить Windows и использовать бесплатное ПО для программирования роботов.
суббота, 30 июня 2018 г.
Программирование на NXT-G под Linux
Особенности:
1 NXT-G — это графический язык программирования Lego-роботов, под него разработана среда Lego MindStorms NXT 2.0.
3 Запуск будет проводится с помощью программы wine (она позволяет запускать windows-приложения — в основном 32-битные — на linux). Функционал программы будет полностью работать, за исключением работы с NXT-блоком по USB и Bluetooth.
4 У программы wine есть проблемы взаимодейстсвия с USB-устройствами. Несмотря на то, что подключение флешек она видит, мой NXT-блок она так и не увидела (на официальном сайте wine также описана эта проблема). Поэтому взаимодействовать по USB-проводу с NXT-блоком не получится, как и по Bluetooth (( Для этого мы воспользуемся другой программой — компилятором nbc, который также позволяет загружать файлы на NXT-блок. Но обо всём по порядку.
Замечание. NXT-блок так же можно программировать на текстовом си-подобном языке, читайте об этом в статье «Программирование NXT-блока на си-подобном NXC» (здесь скоро появится ссылка!).
Совет. Команды можно не перепечатывать, а копировать и вставлять в терминал (комбинации Ctrl + Insert / Shift + Insert)
Итак, у меня есть доступ к интернету (для скачивания 32-битного установщика Lego Mindstorms NXT) и 64-разрядная с истема Mint 18.3. Если вы ещё не передумали, то переходим к установке.
Установка Lego Mindstorms NXT
1 У меня уже установлен wine и winetricks — программы для запуска windows приложений на linux. Если они у вас не установлены, то см. инструкцию как это сделать из статьи «Программирование на EV3-G под Linux», если установлены я настойчиво рекомендую переустановить. Так сказать, для чистоты эксперимента.
3 Создаём новую «бутылку» wine для программы LEGO Mindstorms NXT. Т.к. ранее я уже использовал программу wine (я установил LEGO Mindstorms EV3 в папку-«бутылку» ev3 и Компас — в kompas16.1_32), рядом я создам ещё одну папку для LEGO Mindstorms NXT, назову её legoNXT. При этом, если будет программный сбой, вынужденное удаление «бутылки» никак не будет влиять на соседние программы-«бутылки». В этом большое удобство.
(При установке не поддаемся уговорам установить Mono (потому что дальше будем устанавливать Framework), Gecko — можно установить.)
Совет. Команды здесь и далее удобно выделять и копировать в свой терминал. Комбинации Ctrl + Insert / Shift + Insert.
6 Скачиваем с официального сайта Lego программу Lego Mindstorms NXT. Для этого создаём папку в домашней директории, переходим в неё и запускаем скачивание
10 По завершению на Рабочем столе сейчас появилось два ярлыка. Один из них не функционирует, он лишний. Удаляем его
Замечание. Если в процессе установки или во время запуска установленной программы появляются такие окна,
то возможно вы не установили заранее пакет dotnet40 (см. алгоритм установки). Вам нужно удалить папку-«бутылку» legoNXT и повторить установку.
Настройка программы Lego Mindstorms NXT
Программа установлена, запускается и функционирует. Но при подключении NXT -блока к компьютеру сбросить на него ваш код не получится. Проблема известная, из-за неё на сайте wine программа даже получила пониженный бронзовый рейтинг .
Суть решения в следующем. Загрузка управляющей программы на NXT-блок состоит из двух действий: компиляции программы (создаётся бинарный файл) и непосредственно передача программы на NXT-блок. Оба этих действия в обычных условиях происходят подряд. Мы же из разделим. Т.е. будем сохранять бинарный файл на компьютере и отдельно загружать его на NXT-блок с помощью другой программы.
Сохранение бинарного файла на компьютере
Небольшой ликбез. Файл проекта по умолчанию сохраняется на компьютере (с помощью меню File → Save as…) с расширение .rbt, бинарный (исполняемый, скомпилированный rbt-файл) имеет расширение rxe. Именно он нам и нужен. Ещё используются: звуковой файл — .rso, графический — .ric.
К сожалению у программы Lego Mindstorms NXT нет стандартного функционала для сохранения бинарных rxe-файлов проектов. Чтобы сохранить на компьютере такой файл нужно скачать библиотеку DownloadToFile и скопировать её в специальную папку программы по алгоритму.
1. Перейдите в папку программы Lego Mindstorms NXT куда будет помещена библиотека (если вы делали установку по инструкции, указанной выше, пути должны совпасть)
cd "/home/$USER/.local/share/wineprefixes/legoNXT/drive_c/Program Files/LEGO Software/LEGO MINDSTORMS NXT/engine/project"
5. Создайте любой проект, сохраните его ( File → Save as …) и в тоже место сохраните исполняемый файл (меню Tools → Download to File … — не забудьте указать тот же путь! — кнопка Browse и нажмите кнопку Download ). Я сохранил на Рабочий стол под именем First.rxe :
Загрузка бинарного файла на NXT-блок
Для загрузки файла на NXT-блок воспользуемся компилятором nbc, который помимо компилирования замечательного си-подобного текстового языка NXC (о котором читайте в статье ссылка ожидается) даёт удобный способ загрузки файлов на NXT-блок через терминал. Ниже рассмотрим установку компилятора, механизм загрузки и напишем сценарий для автоматической загрузки rxe-файлов по двойному щелчку на них.
3. Проверьте, что подключение прошло успешно. Для этого изучите вывод команды dmesg с подключенным блоком (если реакции нет, изучите инструкцию).
6. Мы будем использовать -b, давая компилятору понять, что файл бинарный и его не нужно компилировать, -d — для загрузки и -S=USB, обозначая передачу файла по USB-каналу.
8. Проверяем. Возьмите в руки NXT-блок. Перейдите My Files → Software files. Первый файл, который вы увидите должен быть First (без расширения).
Замечание. Также можно переносить графические .ric и звуковые файлы .rso, файлы с другими расширениями не будут отображаться в NXT-блоке, хотя и перенесутся в него.
Конечно, загружать таким образом файлы не очень удобно. Поэтому дальше я предлагаю способ автоматизировать этот процесс.
Загрузка rxe-файлов по двойному щелчку
Когда инструкция будет выполнена, двойной щелчок по rxe-файлу будет автоматически загружать его на NXT-блок. Таким образом, наша задача состоит в создании ассоциации между типом файлов .rxe и компилятором nbc с нужными ключами.
Во-первых, нужно создать ярлык для компилятора nbc (сейчас ярлыка нет) — в нём мы должны указать нужные ключи (-b -d -S=USB).
Во-вторых, сейчас по умолчанию rxe-файлы определяются Linux'ом как «двоичный (application/octet-stream)», естественно существуют другие двоичные файлы с другими расширениями или даже без них, которые никакого отношения не имеют к нашим файлам. Поэтому без подготовки нельзя назначить ярлык nbc для работы с rxe-файлами, т. к. система Linux автоматически будет распространять это действие на файлы с любыми расширениями, понимаемые ею как тип «двоичный (application/octet-stream)».
Создание nbc.desktop
1. Ярлык — это тоже файл. Он представляет собой обычный текст, но расширение у него .desktop. Создадим такой файл (для этого можете использовать любой текстовый редактор, я использую nano)
[Desktop Entry]
Name=nbc
Comment=Only for .rxe-, .ric-, .rso-file downloads to the NXT-brick
Exec=gnome-terminal -e "nbc -b -d -S=usb %F"
Terminal=false
Type=Application
StartupNotify=true
MimeType=application/x-nbc;
Icon=application-default-icon
Categories=GNOME;Utility;Development;Engineering;
3. Сохраните изменения и закройте nano. (Для тех, кто nano использует первый раз: Ctrl + O — сохранить, Ctrl + X — выйти.)
Читайте также: