Help Center
  • FAQ
    browse most common questions
  • Live Chat
    talk with our online service
  • Email
    contact your dedicated sales:
  • Call Us
    9:00 - 18:00, Mon.- Fri. (GMT+8)
0

Build an IoT Motion Control Servo System with Raspberry Pi

Published on 2/24/2017 6:54:18 PM

Description

<style>.e_editor{font:14px/24px Arial,'microsoft yahei','Times New Roman','b8bf53';}.e_editor div,e_editor p,e_editor td,e_editor th,e_editor li{font-weight:inherit;font-size:inherit;font-style:inherit;font-family:inherit;}.e_editor ul{margin:-10px 0 20px;}.e_editor li{padding:5px 0;}.e_table{width:96%;border-collapse:collapse;empty-cells:show;}.e_table th,.e_table td{padding:5px;border:2px solid #eee;}.e_img{padding:10px 0;text-align:center;}.e_p{line-height:20px;padding:0 0 20px;text-indent:0em;}</style><p><img src="https://file.allpcb.com/bbs/17/02/24/183406721.jpg" width="500" height="334"/> </p><p> Security and reliable real-time data flow are essential for internet of things (IoT). After seeing a lot of &quot;this side of the press, where the lights will light up&quot; like this kind of hardware, I and a friend wanted to do some obviously in the manipulation of it but almost no sense of the existence of data flow more interactive Something of something! So we decided to build a model that could control the &quot;material&quot; model, that is, imitate your hand movements and show the color on the basis of the finger positioning motion. Hope that with the help of this article, you can make your own hardware products. </p><p><img src="https://file.allpcb.com/bbs/17/02/24/183508768.jpg" width="500" height="272"/> </p><p> The relevant source code about conceptual overview and some more in-depth understanding can be found in the PubNub blog, and the complete code can be found in GitHub library. The article &quot;the LED matrix driver circuit&quot; in Instructable introduces how the LED matrix the drive circuit is written in details. </p><p><br/></p><p><strong>Step 1: Parts and tools</strong> </p><p><strong><br/></strong></p><p> </p><p><img src="https://jpfile1.oss-cn-shenzhen.aliyuncs.com/allpcb/web/image/20190620/6369664132038956081539206.png" alt="Parts and tools.png"/></p><p><br/></p><p> There are a lot of ways to solve this problem, and some of the main ways are listed here. </p><p> Parts </p><p> •Raspberry Pi V1 B + </p><p> •Jump motion controller </p><p> •5V power supply </p><p> •I2C PWM driver </p><p> •4 miniature servos </p><p> •4 miniature servo supporters </p><p> •LED and current limiting resistors </p><p> •Project Chassis </p><p> •Screws, bolts, nuts, paper clips </p><p> •Cable wrap - To keep the wire clean. </p><p> •Power outlets, switches, and cables </p><p> •Toggle switch --- Used to select the servo output mode </p><p> •Small button - Used as restart / shutdown button </p><p> •RGB LED + 2 &amp; TImes; 470 ohm resistance - restart / shutdown indication </p><p> •Supports - To install a variety of parts </p><p> •Wires --- for connection. </p><p> Software and services </p><p> •PubNub - Data Stream Service. Free sandbox mode development. </p><p> •Java SE’s JDK8 - Be sure to get the correct version for your operating system. </p><p> •Jumping showcase and the Java SDK – Be sure to get the correct package for your operating system. </p><p> •PubNub Java SE SDK </p><p> •Java IDE - Choose your favorite, such as JGrasp, NetBeans IntelliJ, or Eclipse </p><p> •Project source code repository - hosted on GitHub </p><p> Raspberry Pi Building </p><p> •PubNub Python Library - This is a more in-depth guide to Raspberry Pi </p><p> •Internet connection - WiFi or Ethernet. </p><p> Tools </p><p> •Computer – Code and check Instructables </p><p> •Drill + Drill bit/ Driver - Drilling, Twist Screws, etc. </p><p> •Dremel rotary tool - for cutting holes in the chassis </p><p> •Hot glue gun </p><p> •Soldering iron + welding </p><p> •Laser cutting machine </p><p> •Screwdriver, pliers, etc </p><p><strong>Step 2: Project Preview</strong> </p><p> Top-level design, divided into three main components: </p><p> 1. Computer and jump motion controller ----- To publish data to the Internet. </p><p> 2. Raspberry Pi in the &quot;box&quot; - subscribe to the data from the internet. </p><p> 3. PubNub - The communication layer to connects these things securely. </p><p> The computer is very easy to handle, but it is more complex in the &quot;box&quot;. </p><p> 1. Raspberry Pi - the main controller with I2C bus communication </p><p> 2. ATMEGA328P matrix drive circuit - through the I2C bus to receive commands, control 28 &amp; TImes; 8 matrix RGB </p><p> 3. Circuit based on TLC5916 LED - controlled by ATMEGA328P, sink LED matrix current </p><p> 4. Adafruit PWM driver - through the I2C bus, driving 4 servos to receive commands </p><p> 5. 5V, 5A power supply </p><p><img src="https://file.allpcb.com/bbs/17/02/24/183635820.png" width="500" height="303"/> </p><p> First, we need to set the computer to use the jump motion controller. </p><p><strong>Step 3: Java and Jump Motion Controller Settings</strong> </p><p><img src="https://file.allpcb.com/bbs/17/02/24/183713067.png"/> </p><p> Java settings </p><p> We will use the Java SDK&#39;s jump motion controller, so we only need to install the Java development kit, which includes the Java operate environment. It is very simple that just choose the correct package for your operating system. </p><p> Instead of creating an installation package, it runs the source code directly from the Java IDE. This allows you to manipulate, modify and learn your own code. When you install the JDK, you need a good IDE, integrated development environment, like IntelliJ and NetBeans in Eclipse. Every user build different library, so you have to refer to the documentation to learn how to set up a new project. </p><p> Java source code </p><p> There is only one Java file that needs to run the code, but you must also install the jump motion and PubNub Java library. The GitHub&#39;s project library contains some necessary Java files. </p><p> Leap settings </p><p> Setting jumps is a bit tricky, and it will vary depending on the system, rather than being done step by step. </p><p> 1. Download the SDK, and run the software and application in the jump motion. </p><p> 2. Install the jump application, which will install all necessary drivers and processes. </p><p> 3. Run the jump motion diagnostics visualization tool to ensure that the jump is working. </p><p> 4. Read the Java SDK documentation, especially the setup. </p><p> PubNub settings </p><p> The last step is to download the PubNub Java SDK, which describes how to add a library to a Java project. </p><p><strong>Step 4: Java source code</strong> </p><p> If you are not interested in Java code, you can skip this step; however, you should at least offer your personal PubNub key to code for it. The source code can be viewed on GitHub. </p><p> Here are some of the imports needed. If errors happen, it is likely that the SDK library is not properly installed. </p><p><img src="https://file.allpcb.com/bbs/17/02/24/183921449.png"/> </p><p> It is vital to achieve Runnable of project and all jump activities work on their own threads. We first focus on project setting. Runnable interface and global variables initialization offer convenience later. The most important thing is the global variable &quot;CHANNEL&quot;, and a pair of keys. </p><p style="text-align:center;"><img src="https://file.allpcb.com/bbs/17/02/24/184025801.png" alt=""/> </p><p> These strings are the only values that can be changed, and their channel names can retain the default &quot;leap2pi&quot; or some other alphas and numbers. It is necessary to use a unique name to prevent crosstalk between different projects. </p><p> Jump motion captures 300 frames per second. At every frame, we are able to get a lot of information, such as finger straightening, pitching, yawing and gestures. The value returned by the leaping pitch and yaw is radian, which is not helpful. We want to convert these valuesto the format accepted by the PWM driver. We first convert radians to degrees and then degrees between 150 and 600, which is equivalent to a servo. The acceptable servo PWM values for the typical operating range areexpressed by a 12-bit servo drive. </p><p> The basic formula in US is 2500 / (2 ^ 13-1) * (min. servo / max pulse width), so that [500, 2000] can map to [150,600]. </p><p style="text-align:center;"><img src="https://file.allpcb.com/bbs/17/02/24/184105676.png" alt=""/> </p><p> The best way to make sure your code is working is to load the PubNub debug console. You can enter the channel name as publish and subscribe keys. Click on &quot;Subscribe&quot;, when operate jump motion controller to run the Java code, the published data should be displayed in the message box. </p><p><strong>Step 5: Install Raspberry Pi</strong> </p><p style="text-align:center;"><strong><img src="https://jpfile1.oss-cn-shenzhen.aliyuncs.com/allpcb/web/image/20190605/6369534500879336156551120.png" alt="184132645.png" title="undefined" width="500" height="330" align=""/><br/></strong> </p><p> With the operation of the Java code, it is time to set the Raspberry Pi dispatch data and use it to drive the LEDs and servos. In the already configured raspberry work with an internet connection, it can be WiFi or Ethernet, but this part needs you to finish! If you need help, you can find it on PubNub (someone wrote some time ago). In addition, you can use the monitor and keyboard directly on Pi to complete any one step, or use SSH remote login. Either way, but the ultimate goal of the project is to have a separate, no head, the installer will automatically run the required files to start. </p><p> The first step is to install the PubNub Python SDK. </p><p> Open the terminal and install the following: </p><p style="text-align:center;"><img src="https://file.allpcb.com/bbs/17/02/24/184207284.jpg" alt=""/> </p><p> It&#39;s very simple. Now we need to get a copy of all the files in the Pi directory of GitHub&#39;s repository. The easiest way to do this is to use Git clone to repurchase and then delete other unnecessary things: </p><p style="text-align:center;"><img src="https://file.allpcb.com/bbs/17/02/24/185256969.png" alt=""/> </p><p> The contents of the leap2pi directory should be the same as the files in the Pi directory of GitHub library. Finally, we want the Python script to start running. Here are two Python scripts to run: </p><p style="text-align:center;"><img src="https://file.allpcb.com/bbs/17/02/24/185341539.jpg" alt=""/> </p><p> It is so simple that we only need to edit a Linux system file as the root user. First, make sure the script is executable, and then open the rc.local file for editing. </p><p style="text-align:center;"><img src="https://file.allpcb.com/bbs/17/02/24/185405518.jpg" alt=""/> </p><p> You can use any of your favorite editors. The last line of the file should be &quot;exit 0&quot;, which is to allow the use of the file clean export and terminal initialization. Here you can add any number of commands as long as they run the last &quot;exit&quot; command. </p><p> Insert the following, just above the &quot;exit 0&quot; command: </p><p style="text-align:center;"><img src="https://file.allpcb.com/bbs/17/02/24/185042087.png" alt=""/> </p><p> Save the file and exit. Pi will automatically run these scripts after starting up. The &quot;&amp;&amp;&quot; section ensures that every command runs. If you leave off, the bash terminal will always be loaded, so your personal information will be locked indefinitely. </p><p><strong>Step 6: Connection between Raspberry Pi and servo drive</strong> </p><p style="text-align:center;"><strong><img src="https://jpfile1.oss-cn-shenzhen.aliyuncs.com/allpcb/web/image/20190605/6369534239983241607020167.png" alt="184908921.png" title="undefined" width="500" height="424" align=""/><br/></strong> </p><p> Raspberry Pi can drive the servo system directly, but it takes some effort. There is a dedicated PWM channel, but we need four wires. As a computer, Raspberry Pi is much better at the top level control than the low one. </p><p> It is easy to connect the Raspberry Pi. Pin 3 and 5 are found on the raspberry dispatched I2C line, but in this case it is also necessary to open the I2C communication channel and remember to view it. An important input pin is labeled &quot;OE&quot;, ie the active-low &quot;output enable&quot; pin, when this pin remains low, the servo system is enabled, it can be connected directly to ground, or drive another One end IO pin. In this project, it is also from the ATMEGA328P matrix drive circuit also uses the I2C data line to connect to the R group. </p><p> In this figure, the servo is attached to the channel 1 PWM drive. In the project, set up such a steering gear like this: </p><p style="text-align:center;"><img src="https://file.allpcb.com/bbs/17/02/24/184847095.jpg" alt=""/> </p><p><strong>Step 7: Close view on servo.py</strong> </p><p> It is easy to control servos with Python code as long as you understand Python. You can view this copy of the servo.py file on GitHub. </p><p> Like Java code, you need to publish your personal PubNub, where you subscribe to the key, and the name of the communication channel. </p><p> The Raspberry Pi will guide to do the following: </p><p> 1. Reset the AVR matrix drive circuit. </p><p> 2. Initialize PubNub with your key. </p><p> 3. Subscribe to the PubNub channel &quot;leap2pi&quot;. </p><p> 4. Cycle down and check the output mode switch. </p><p> At the bottom of the system, all the work is done in the PubNub library. It will call all the operations and we only need to specify some callback. </p><p style="text-align:center;"><img src="https://file.allpcb.com/bbs/17/02/24/184824450.png" alt=""/> </p><p> The connection callback should be obvious. This function is actually doing things from the subscribe channel to receive messages. As described above, the box has a pair of output patterns selected for the slide switch connected to several IO lines. </p><p> •Mirror - The robot will reflect your movements; therefore, your left hand reverse control robot. </p><p> •Disabled - The servo system will stop responding. </p><p> •Clone - The robot will clone your movements; therefore, your left hand directly controls the left robot. </p><p> The only item worth noting in this file is to use GPIO pin 4 as the output. This pin drives the MOSFET to connect the gate of blue LED ground array. </p><p style="text-align:center;"><img src="https://jpfile1.oss-cn-shenzhen.aliyuncs.com/allpcb/web/image/20190605/6369534509612859204000903.png" alt="184745005.png" title="undefined" width="500" height="375" align=""/> </p><p><strong>Step 8: Close view on shutdown.py</strong> </p><p> Since Raspberry Pi is also used as a full-featured computer and should be properly shut down. It can cause drive failure, data loss and memory damage. </p><p> In order to solve this problem, I installed a simple button on the back of the box with an RGB LED. Press the button more than a second will turn to blue light, and Raspberry Pi will restart when the button is released. Press the button for a few seconds again will cause the LED to turn red and the signal will be turned off completely. </p><p style="text-align:center;"><img src="https://jpfile1.oss-cn-shenzhen.aliyuncs.com/allpcb/web/image/20190604/6369526611988781394938081.png" alt="184650319.png"/></p><p> This feature is fully processed under the shutdown.py script. The following will occur in permanent cycle: </p><p> 1.0.25 seconds sleep state </p><p> 2. Check to press a button (low on pin) </p><p> 3. Repeat forever </p><p><strong>Step 9: Build the box</strong> </p><p style="text-align:center;"><strong><img src="https://jpfile1.oss-cn-shenzhen.aliyuncs.com/allpcb/web/image/20190604/6369526518422113792304971.png" alt="184536278.png"/></strong> </p><p> When building this box, we create a pair of vector files in Illustrator. These were sent to the laser cutting company (Ponoko), which gave us a bunch of laser cutting wood and acrylic. The fragments are still very large when they are sent back, making us have the joy of assembling them. </p><p> If you are careful, you can drill holes in acrylic (and wood) and install them with small screws. If you do not want to do this, you can arbitrarily build the box you want. But the supporter should be used to keep the circuit components securely mounted to the base, or to reduce some additional holes. Besides, install the power outlet, buttons and RGB lead on the back of the box. </p><p> The most important thing is the installation of the servo driller. When they are moving, the servo will cause fall or jump around of frame with light weight. Crucially, they were firmly installed on a sturdy surface, and we choose the cover of box. </p><p><strong>Step 10: Complete</strong> </p><p> Some parts need to be customized, especially the actual box and servo supporter. </p>

55

comment

All comments

Unknown

5360

0

55

Go to Order My Own PCB

Rules about cashback: 1. Valid time: ALLPCB cashback activity will end on April 1st. 2. Capped amount: The capped amount of cashback for each account is $5,000. Each order can get a maximum of $2,000 cashback. That means every author can get $5,000 max. 3. Cashback range: The cashback activity only covers the corresponding PCB order. The order amount for other combined payment products will be invalid. 4. Clicking your own promotional link will be invalid. The same email address, shipping address, contact information, and phone number are all recognized as the same account. 5. ALLPCB has the final interpretation right of the cashback activity.

ALLPCB will donate 2% to the author for this promotion link.

Other Projects

Home / Industrial Automation low Cost with Arduino an ESP01

2488

0

314

Alternate Text josemarjr