(Created page with "{{NAWI_Graz:navbar}} {{NAWI_Graz:footer}}") |
Holzfigure (Talk | contribs) |
||
(4 intermediate revisions by 3 users not shown) | |||
Line 1: | Line 1: | ||
{{NAWI_Graz:navbar}} | {{NAWI_Graz:navbar}} | ||
+ | <html> | ||
+ | <div class="jumbotron"> | ||
+ | <div class="section section-heading container"> | ||
+ | <h1>CONTROL SYSTEM</h1> | ||
+ | </div> | ||
+ | <div class="section-text container"> | ||
+ | The integration of the living and inanimate components of the | ||
+ | <command class="colibot" /> project of course requires a reliable and thought-through architecture of control systems. Based on the | ||
+ | <a href="https://www.raspberrypi.org/products/raspberry-pi-3-model-b/">Raspberry Pi</a> single board computer, we devised a server / client system that manages actuation, measurement and | ||
+ | intra-system interaction. Running on Raspbian Linux and written in Python3, both very well documented approaches | ||
+ | for hardware - software interfaces, our system is highly adaptable, scalable and offers flexibility during the experimental | ||
+ | development of new functionality. The wide availability and low cost of all the hardware components used in the | ||
+ | control system of | ||
+ | <command class="colibot" /> ties well into our concept of engineering without financial hurdles that could slow down or inhibit developement | ||
+ | and innovation. | ||
+ | </div> | ||
+ | </div> | ||
+ | |||
+ | <div class="section container"> | ||
+ | <h2 class="section-sub">The | ||
+ | <command class="colibot" /> Server</h2> | ||
+ | <div class="section-text container"> | ||
+ | <p> | ||
+ | Our server was built and programmed as the centerpiece of the control architecture that encompasses the bioreactor and measurement | ||
+ | system of | ||
+ | <command class="colibot" /> and as communication hub between scientists, reactor and robot. The single-board Raspberry Pi hardware platform | ||
+ | that is present in all parts of the system is also the base of the server component. Connected to the | ||
+ | other hardware components via the GPIO (general purpose input output) interface, and communicating with the robot | ||
+ | and client via UDP, the server is the central information hub and controller of the system. | ||
+ | </p> | ||
+ | <p>The server code controls the interaction modules, the measurement chambers and the communication with the robot in | ||
+ | the arena. It listens for commands that are sent by either the robot or the client software and reacts by executing | ||
+ | the following functions. | ||
+ | <p> | ||
+ | <h3 class="section-sub-sub">Directly available | ||
+ | <command class="colibot" />-Server functions activated by commands sent from client:</h3> | ||
+ | <ul class="list-group"> | ||
+ | <li class="list-group-item"> | ||
+ | <code class="server-command">heat</code> Starts the heating module for 5 seconds. | ||
+ | </li> | ||
+ | <li class="list-group-item"> | ||
+ | <code class="server-command">pump_1</code> Start all pumps for 11 seconds (the length of one measure cycle) to flush the system | ||
+ | and fill it with fresh suspension from the reactor. | ||
+ | </li> | ||
+ | <li class="list-group-item"> | ||
+ | <code class="server-command">temp</code> Get the current temperature reading from the themperature sensor in the | ||
+ | <a href="https://2017.igem.org/Team:NAWI_Graz/TemperatureModule">Temperature Interaction Module</a>. | ||
+ | </li> | ||
+ | <li class="list-group-item"> | ||
+ | <code class="server-command">cam</code> Take a testpicture with the master camera and report the measurement result. | ||
+ | </li> | ||
+ | <li class="list-group-item"> | ||
+ | <code class="server-command">drive</code> Send out a | ||
+ | <code>drive</code> command to the Robot to test range and connection. | ||
+ | </li> | ||
+ | <li class="list-group-item"> | ||
+ | <code class="server-command">turn</code> Send out a | ||
+ | <code>turn</code> command to the Robot to calibrate the radius. | ||
+ | </li> | ||
+ | </ul> | ||
+ | <div class="section-sub-text container"> | ||
+ | <b>Tab. 1: </b>List of commands and the corresponding functionality in the servercode. | ||
+ | </div> | ||
+ | |||
+ | </p> | ||
+ | </p> | ||
+ | |||
+ | <p> | ||
+ | In the case of a real experiment run in the temperature setup, the robot sends one of the following messages to the server | ||
+ | according to its position and orientation in the arena and the sensor input it perceives. The server reacts by | ||
+ | initiating the corresponding processes as described below. | ||
+ | <h3 class="section-sub-sub">Robot - Server Interaction :</h3> | ||
+ | <ul class="list-group"> | ||
+ | <li class="row list-group-item"> | ||
+ | <code class="col-1 server-command">clear</code> | ||
+ | <p class="col">The server starts a waiting loop to cool down the potentially still hot heating chamber to prevent tainting | ||
+ | the current run by previous runs. After this cool-down period, fresh suspension is pumped into | ||
+ | the measurement chamber and a baseline measurement is conducted. To prevent any unknown or outside | ||
+ | influences, another waiting loop, identical in duration to the activation heating period during a | ||
+ | run with activated temperature interaction, is started now. Finally, the suspension is pumped | ||
+ | into the measurement chamber and a measurement is taken. The baseline measurement and actual measurement | ||
+ | data is now compared and in case the difference surpasses a given threshold, the server sends the | ||
+ | <code>turn</code> command to the robot. Otherwise | ||
+ | <code>drive</code> sent to the robot to signal an open path ahead.</p> | ||
+ | </li> | ||
+ | |||
+ | <div class="section-sub-text container"> | ||
+ | <b>Tab. 2: </b>List of commands for server interaction. | ||
+ | </div> | ||
+ | |||
+ | <li class="row list-group-item"> | ||
+ | <code class="col-1 server-command">obstacle</code> | ||
+ | <p class="col">The server starts with a cool-down period to prevent tainted measuring results. A baseline measurement | ||
+ | is made with fresh suspension. Fresh suspension is pumped into the temperature interaction module | ||
+ | and heated to target temperature. The heated and activated suspension is pumped into the measurement | ||
+ | chamber and a measurement is taken and compared to the baseline value. If the baseline and the actual | ||
+ | measurement have a difference equal or greater than the given threshold, the server sends the | ||
+ | <code>turn</code> command to the robot. Otherwise | ||
+ | <code>drive</code> sent to the robot to signal an open path ahead. | ||
+ | <p> | ||
+ | </li> | ||
+ | </ul> | ||
+ | </p> | ||
+ | |||
+ | </div> | ||
+ | </div> | ||
+ | <br> | ||
+ | |||
+ | <div class="section container"> | ||
+ | <h2 class="section-sub">The | ||
+ | <command class="colibot" /> Client</h2> | ||
+ | <div class="section-text container"> | ||
+ | <p>To be able to test all of the control systems functionality (pump control, heating, measurements) without having | ||
+ | to actually run the full experiments, a small command line application was written in Python3. Intended to being | ||
+ | run on any computer in the same network as the | ||
+ | <command class="colibot" /> Server and | ||
+ | <a class="intralink" href="https://2017.igem.org/Team:NAWI_Graz/Robot">Robot</a>, this application allowed us to conveniently send the above mentioned commands to the server for testing | ||
+ | and verification of the componenets of the bioreactor setup and robot. Especially during the calibration of the | ||
+ | interaction modules and pump cycle lengths, this little tool proved to be very useful.</p> | ||
+ | <p>The commands are sent and answers are received over | ||
+ | <a href="https://en.wikipedia.org/wiki/User_Datagram_Protocol">UDP</a>, a common data transfer protocol. Although not reliable for critical communication because of missing | ||
+ | error checking and guaranteed order of the packets arriving, for the small data packets we are sending here it | ||
+ | is sufficient. </li> | ||
+ | </ul> | ||
+ | </p> | ||
+ | |||
+ | <br> <br> | ||
+ | <div class="section-text container"> | ||
+ | <p> | ||
+ | The client code for testing the system functionality: | ||
+ | |||
+ | |||
+ | </p> | ||
+ | <!-- HTML generated using hilite.me --><div style="background: #f8f8f8; overflow:auto;width:auto;border:solid gray;border-width:.1em .1em .1em .8em;padding:.2em .6em;"><table><tr><td><pre style="margin: 0; line-height: 125%"> 1 | ||
+ | 2 | ||
+ | 3 | ||
+ | 4 | ||
+ | 5 | ||
+ | 6 | ||
+ | 7 | ||
+ | 8 | ||
+ | 9 | ||
+ | 10 | ||
+ | 11 | ||
+ | 12 | ||
+ | 13 | ||
+ | 14 | ||
+ | 15 | ||
+ | 16 | ||
+ | 17 | ||
+ | 18 | ||
+ | 19 | ||
+ | 20 | ||
+ | 21 | ||
+ | 22 | ||
+ | 23 | ||
+ | 24 | ||
+ | 25 | ||
+ | 26 | ||
+ | 27 | ||
+ | 28 | ||
+ | 29 | ||
+ | 30 | ||
+ | 31 | ||
+ | 32 | ||
+ | 33 | ||
+ | 34 | ||
+ | 35 | ||
+ | 36 | ||
+ | 37 | ||
+ | 38 | ||
+ | 39 | ||
+ | 40 | ||
+ | 41 | ||
+ | 42 | ||
+ | 43</pre></td><td><pre style="margin: 0; line-height: 125%"><span style="color: #8f5902; font-style: italic">#!/usr/sbin/python3</span> | ||
+ | <span style="color: #8f5902; font-style: italic"># ColiBot Client</span> | ||
+ | <span style="color: #8f5902; font-style: italic"># -</span> | ||
+ | <span style="color: #8f5902; font-style: italic"># A minimal udp messaging client to send (test) messages to the ColiBot server.</span> | ||
+ | <span style="color: #8f5902; font-style: italic">#</span> | ||
+ | <span style="color: #204a87; font-weight: bold">import</span> <span style="color: #000000">socket</span> | ||
+ | <span style="color: #204a87; font-weight: bold">import</span> <span style="color: #000000">sys</span> | ||
+ | |||
+ | <span style="color: #8f5902; font-style: italic"># create datagram udp socket</span> | ||
+ | <span style="color: #204a87; font-weight: bold">try</span><span style="color: #000000; font-weight: bold">:</span> | ||
+ | <span style="color: #000000">sock</span> <span style="color: #ce5c00; font-weight: bold">=</span> <span style="color: #000000">socket</span><span style="color: #ce5c00; font-weight: bold">.</span><span style="color: #000000">socket</span><span style="color: #000000; font-weight: bold">(</span><span style="color: #000000">socket</span><span style="color: #ce5c00; font-weight: bold">.</span><span style="color: #000000">AF_INET</span><span style="color: #000000; font-weight: bold">,</span> <span style="color: #000000">socket</span><span style="color: #ce5c00; font-weight: bold">.</span><span style="color: #000000">SOCK_DGRAM</span><span style="color: #000000; font-weight: bold">)</span> | ||
+ | <span style="color: #204a87; font-weight: bold">except</span> <span style="color: #000000">socket</span><span style="color: #ce5c00; font-weight: bold">.</span><span style="color: #000000">error</span><span style="color: #000000; font-weight: bold">:</span> | ||
+ | <span style="color: #204a87">print</span><span style="color: #000000; font-weight: bold">(</span><span style="color: #4e9a06">'Failed to create socket'</span><span style="color: #000000; font-weight: bold">)</span> | ||
+ | <span style="color: #000000">sys</span><span style="color: #ce5c00; font-weight: bold">.</span><span style="color: #000000">exit</span><span style="color: #000000; font-weight: bold">()</span> | ||
+ | |||
+ | <span style="color: #000000">host</span> <span style="color: #ce5c00; font-weight: bold">=</span> <span style="color: #4e9a06">'192.168.0.4'</span> | ||
+ | <span style="color: #000000">port</span> <span style="color: #ce5c00; font-weight: bold">=</span> <span style="color: #0000cf; font-weight: bold">4343</span> | ||
+ | |||
+ | <span style="color: #204a87; font-weight: bold">while</span><span style="color: #000000; font-weight: bold">(</span><span style="color: #0000cf; font-weight: bold">1</span><span style="color: #000000; font-weight: bold">):</span> | ||
+ | <span style="color: #000000">msg</span> <span style="color: #ce5c00; font-weight: bold">=</span> <span style="color: #204a87">input</span><span style="color: #000000; font-weight: bold">(</span><span style="color: #4e9a06">'Enter message to send : '</span><span style="color: #000000; font-weight: bold">)</span> | ||
+ | <span style="color: #204a87; font-weight: bold">try</span><span style="color: #000000; font-weight: bold">:</span> | ||
+ | <span style="color: #8f5902; font-style: italic"># Send string</span> | ||
+ | <span style="color: #000000">sock</span><span style="color: #ce5c00; font-weight: bold">.</span><span style="color: #000000">sendto</span><span style="color: #000000; font-weight: bold">(</span><span style="color: #204a87">str</span><span style="color: #ce5c00; font-weight: bold">.</span><span style="color: #000000">encode</span><span style="color: #000000; font-weight: bold">(</span><span style="color: #000000">msg</span><span style="color: #000000; font-weight: bold">),</span> <span style="color: #000000; font-weight: bold">(</span><span style="color: #000000">host</span><span style="color: #000000; font-weight: bold">,</span> <span style="color: #000000">port</span><span style="color: #000000; font-weight: bold">))</span> | ||
+ | |||
+ | <span style="color: #8f5902; font-style: italic"># receive data from client (data, addr)</span> | ||
+ | <span style="color: #000000">d</span> <span style="color: #ce5c00; font-weight: bold">=</span> <span style="color: #000000">sock</span><span style="color: #ce5c00; font-weight: bold">.</span><span style="color: #000000">recvfrom</span><span style="color: #000000; font-weight: bold">(</span><span style="color: #0000cf; font-weight: bold">1024</span><span style="color: #000000; font-weight: bold">)</span> | ||
+ | <span style="color: #000000">reply</span> <span style="color: #ce5c00; font-weight: bold">=</span> <span style="color: #000000">d</span><span style="color: #000000; font-weight: bold">[</span><span style="color: #0000cf; font-weight: bold">0</span><span style="color: #000000; font-weight: bold">]</span> | ||
+ | <span style="color: #000000">addr</span> <span style="color: #ce5c00; font-weight: bold">=</span> <span style="color: #000000">d</span><span style="color: #000000; font-weight: bold">[</span><span style="color: #0000cf; font-weight: bold">1</span><span style="color: #000000; font-weight: bold">]</span> | ||
+ | |||
+ | <span style="color: #204a87">print</span><span style="color: #000000; font-weight: bold">(</span><span style="color: #4e9a06">'Server reply : '</span> <span style="color: #ce5c00; font-weight: bold">+</span> <span style="color: #204a87">str</span><span style="color: #000000; font-weight: bold">(</span><span style="color: #000000">reply</span><span style="color: #000000; font-weight: bold">))</span> | ||
+ | <span style="color: #204a87; font-weight: bold">if</span> <span style="color: #000000; font-weight: bold">(</span><span style="color: #000000">reply</span><span style="color: #ce5c00; font-weight: bold">.</span><span style="color: #000000">decode</span><span style="color: #000000; font-weight: bold">(</span><span style="color: #4e9a06">"utf-8"</span><span style="color: #000000; font-weight: bold">)</span> <span style="color: #ce5c00; font-weight: bold">==</span> <span style="color: #4e9a06">'turn'</span><span style="color: #000000; font-weight: bold">):</span> | ||
+ | <span style="color: #204a87">print</span><span style="color: #000000; font-weight: bold">(</span><span style="color: #4e9a06">"Got 'turn' message."</span><span style="color: #000000; font-weight: bold">)</span> | ||
+ | <span style="color: #204a87; font-weight: bold">if</span> <span style="color: #000000; font-weight: bold">(</span><span style="color: #000000">reply</span><span style="color: #ce5c00; font-weight: bold">.</span><span style="color: #000000">decode</span><span style="color: #000000; font-weight: bold">(</span><span style="color: #4e9a06">"utf-8"</span><span style="color: #000000; font-weight: bold">)</span> <span style="color: #ce5c00; font-weight: bold">==</span> <span style="color: #4e9a06">'drive'</span><span style="color: #000000; font-weight: bold">):</span> | ||
+ | <span style="color: #204a87">print</span><span style="color: #000000; font-weight: bold">(</span><span style="color: #4e9a06">"Got 'drive' message."</span><span style="color: #000000; font-weight: bold">)</span> | ||
+ | |||
+ | <span style="color: #204a87; font-weight: bold">except</span> <span style="color: #000000">socket</span><span style="color: #ce5c00; font-weight: bold">.</span><span style="color: #000000">error</span> <span style="color: #204a87; font-weight: bold">as</span> <span style="color: #000000">e</span><span style="color: #000000; font-weight: bold">:</span> | ||
+ | <span style="color: #204a87">print</span><span style="color: #000000; font-weight: bold">(</span><span style="color: #4e9a06">'Socket Error: {}'</span><span style="color: #ce5c00; font-weight: bold">.</span><span style="color: #000000">format</span><span style="color: #000000; font-weight: bold">(</span><span style="color: #000000">e</span><span style="color: #000000; font-weight: bold">))</span> | ||
+ | <span style="color: #000000">sock</span><span style="color: #ce5c00; font-weight: bold">.</span><span style="color: #000000">close</span><span style="color: #000000; font-weight: bold">()</span> | ||
+ | <span style="color: #000000">sys</span><span style="color: #ce5c00; font-weight: bold">.</span><span style="color: #000000">exit</span><span style="color: #000000; font-weight: bold">()</span> | ||
+ | |||
+ | <span style="color: #204a87; font-weight: bold">except</span> <span style="color: #cc0000; font-weight: bold">KeyboardInterrupt</span><span style="color: #000000; font-weight: bold">:</span> | ||
+ | <span style="color: #000000">sock</span><span style="color: #ce5c00; font-weight: bold">.</span><span style="color: #000000">close</span><span style="color: #000000; font-weight: bold">()</span> | ||
+ | <span style="color: #000000">sys</span><span style="color: #ce5c00; font-weight: bold">.</span><span style="color: #000000">exit</span><span style="color: #000000; font-weight: bold">()</span> | ||
+ | </pre></td></tr></table></div> | ||
+ | </div> | ||
+ | <br> <br> | ||
+ | <div class="section-text container"> | ||
+ | <p> | ||
+ | The server code for controlling the bioreactor and measurement system: | ||
+ | |||
+ | |||
+ | </p> | ||
+ | |||
+ | |||
+ | |||
+ | |||
+ | <!-- HTML generated using hilite.me --><div style="background: #f8f8f8; overflow:auto;width:auto;border:solid gray;border-width:.1em .1em .1em .8em;padding:.2em .6em;"><table><tr><td><pre style="margin: 0; line-height: 125%"> 1 | ||
+ | 2 | ||
+ | 3 | ||
+ | 4 | ||
+ | 5 | ||
+ | 6 | ||
+ | 7 | ||
+ | 8 | ||
+ | 9 | ||
+ | 10 | ||
+ | 11 | ||
+ | 12 | ||
+ | 13 | ||
+ | 14 | ||
+ | 15 | ||
+ | 16 | ||
+ | 17 | ||
+ | 18 | ||
+ | 19 | ||
+ | 20 | ||
+ | 21 | ||
+ | 22 | ||
+ | 23 | ||
+ | 24 | ||
+ | 25 | ||
+ | 26 | ||
+ | 27 | ||
+ | 28 | ||
+ | 29 | ||
+ | 30 | ||
+ | 31 | ||
+ | 32 | ||
+ | 33 | ||
+ | 34 | ||
+ | 35 | ||
+ | 36 | ||
+ | 37 | ||
+ | 38 | ||
+ | 39 | ||
+ | 40 | ||
+ | 41 | ||
+ | 42 | ||
+ | 43 | ||
+ | 44 | ||
+ | 45 | ||
+ | 46 | ||
+ | 47 | ||
+ | 48 | ||
+ | 49 | ||
+ | 50 | ||
+ | 51 | ||
+ | 52 | ||
+ | 53 | ||
+ | 54 | ||
+ | 55 | ||
+ | 56 | ||
+ | 57 | ||
+ | 58 | ||
+ | 59 | ||
+ | 60 | ||
+ | 61 | ||
+ | 62 | ||
+ | 63 | ||
+ | 64 | ||
+ | 65 | ||
+ | 66 | ||
+ | 67 | ||
+ | 68 | ||
+ | 69 | ||
+ | 70 | ||
+ | 71 | ||
+ | 72 | ||
+ | 73 | ||
+ | 74 | ||
+ | 75 | ||
+ | 76 | ||
+ | 77 | ||
+ | 78 | ||
+ | 79 | ||
+ | 80 | ||
+ | 81 | ||
+ | 82 | ||
+ | 83 | ||
+ | 84 | ||
+ | 85 | ||
+ | 86 | ||
+ | 87 | ||
+ | 88 | ||
+ | 89 | ||
+ | 90 | ||
+ | 91 | ||
+ | 92 | ||
+ | 93 | ||
+ | 94 | ||
+ | 95 | ||
+ | 96 | ||
+ | 97 | ||
+ | 98 | ||
+ | 99 | ||
+ | 100 | ||
+ | 101 | ||
+ | 102 | ||
+ | 103 | ||
+ | 104 | ||
+ | 105 | ||
+ | 106 | ||
+ | 107 | ||
+ | 108 | ||
+ | 109 | ||
+ | 110 | ||
+ | 111 | ||
+ | 112 | ||
+ | 113 | ||
+ | 114 | ||
+ | 115 | ||
+ | 116 | ||
+ | 117 | ||
+ | 118 | ||
+ | 119 | ||
+ | 120 | ||
+ | 121 | ||
+ | 122 | ||
+ | 123 | ||
+ | 124 | ||
+ | 125 | ||
+ | 126 | ||
+ | 127 | ||
+ | 128 | ||
+ | 129 | ||
+ | 130 | ||
+ | 131 | ||
+ | 132 | ||
+ | 133 | ||
+ | 134 | ||
+ | 135 | ||
+ | 136 | ||
+ | 137 | ||
+ | 138 | ||
+ | 139 | ||
+ | 140 | ||
+ | 141 | ||
+ | 142 | ||
+ | 143 | ||
+ | 144 | ||
+ | 145 | ||
+ | 146 | ||
+ | 147 | ||
+ | 148 | ||
+ | 149 | ||
+ | 150 | ||
+ | 151 | ||
+ | 152 | ||
+ | 153 | ||
+ | 154 | ||
+ | 155 | ||
+ | 156 | ||
+ | 157 | ||
+ | 158 | ||
+ | 159 | ||
+ | 160 | ||
+ | 161 | ||
+ | 162 | ||
+ | 163 | ||
+ | 164 | ||
+ | 165 | ||
+ | 166 | ||
+ | 167 | ||
+ | 168 | ||
+ | 169 | ||
+ | 170 | ||
+ | 171 | ||
+ | 172 | ||
+ | 173 | ||
+ | 174 | ||
+ | 175 | ||
+ | 176 | ||
+ | 177 | ||
+ | 178 | ||
+ | 179 | ||
+ | 180 | ||
+ | 181 | ||
+ | 182 | ||
+ | 183 | ||
+ | 184 | ||
+ | 185 | ||
+ | 186 | ||
+ | 187 | ||
+ | 188 | ||
+ | 189 | ||
+ | 190 | ||
+ | 191 | ||
+ | 192 | ||
+ | 193 | ||
+ | 194 | ||
+ | 195 | ||
+ | 196 | ||
+ | 197 | ||
+ | 198 | ||
+ | 199 | ||
+ | 200 | ||
+ | 201 | ||
+ | 202 | ||
+ | 203 | ||
+ | 204 | ||
+ | 205 | ||
+ | 206 | ||
+ | 207 | ||
+ | 208 | ||
+ | 209 | ||
+ | 210 | ||
+ | 211 | ||
+ | 212 | ||
+ | 213 | ||
+ | 214 | ||
+ | 215 | ||
+ | 216 | ||
+ | 217 | ||
+ | 218 | ||
+ | 219 | ||
+ | 220 | ||
+ | 221 | ||
+ | 222 | ||
+ | 223 | ||
+ | 224 | ||
+ | 225 | ||
+ | 226 | ||
+ | 227 | ||
+ | 228 | ||
+ | 229 | ||
+ | 230 | ||
+ | 231 | ||
+ | 232 | ||
+ | 233 | ||
+ | 234 | ||
+ | 235 | ||
+ | 236 | ||
+ | 237 | ||
+ | 238 | ||
+ | 239 | ||
+ | 240 | ||
+ | 241 | ||
+ | 242 | ||
+ | 243 | ||
+ | 244 | ||
+ | 245 | ||
+ | 246 | ||
+ | 247 | ||
+ | 248 | ||
+ | 249 | ||
+ | 250 | ||
+ | 251 | ||
+ | 252 | ||
+ | 253 | ||
+ | 254 | ||
+ | 255 | ||
+ | 256 | ||
+ | 257 | ||
+ | 258 | ||
+ | 259 | ||
+ | 260 | ||
+ | 261 | ||
+ | 262 | ||
+ | 263 | ||
+ | 264 | ||
+ | 265 | ||
+ | 266 | ||
+ | 267 | ||
+ | 268 | ||
+ | 269 | ||
+ | 270 | ||
+ | 271 | ||
+ | 272 | ||
+ | 273 | ||
+ | 274 | ||
+ | 275 | ||
+ | 276 | ||
+ | 277 | ||
+ | 278 | ||
+ | 279 | ||
+ | 280 | ||
+ | 281 | ||
+ | 282 | ||
+ | 283 | ||
+ | 284 | ||
+ | 285 | ||
+ | 286 | ||
+ | 287 | ||
+ | 288 | ||
+ | 289 | ||
+ | 290 | ||
+ | 291 | ||
+ | 292 | ||
+ | 293 | ||
+ | 294 | ||
+ | 295 | ||
+ | 296 | ||
+ | 297 | ||
+ | 298 | ||
+ | 299 | ||
+ | 300 | ||
+ | 301 | ||
+ | 302 | ||
+ | 303 | ||
+ | 304 | ||
+ | 305 | ||
+ | 306 | ||
+ | 307 | ||
+ | 308 | ||
+ | 309 | ||
+ | 310 | ||
+ | 311 | ||
+ | 312 | ||
+ | 313 | ||
+ | 314 | ||
+ | 315 | ||
+ | 316 | ||
+ | 317 | ||
+ | 318 | ||
+ | 319 | ||
+ | 320 | ||
+ | 321 | ||
+ | 322 | ||
+ | 323 | ||
+ | 324 | ||
+ | 325 | ||
+ | 326 | ||
+ | 327 | ||
+ | 328 | ||
+ | 329 | ||
+ | 330 | ||
+ | 331 | ||
+ | 332 | ||
+ | 333 | ||
+ | 334 | ||
+ | 335 | ||
+ | 336 | ||
+ | 337 | ||
+ | 338 | ||
+ | 339 | ||
+ | 340 | ||
+ | 341 | ||
+ | 342 | ||
+ | 343 | ||
+ | 344 | ||
+ | 345 | ||
+ | 346 | ||
+ | 347 | ||
+ | 348 | ||
+ | 349 | ||
+ | 350 | ||
+ | 351 | ||
+ | 352 | ||
+ | 353 | ||
+ | 354 | ||
+ | 355 | ||
+ | 356 | ||
+ | 357 | ||
+ | 358 | ||
+ | 359 | ||
+ | 360 | ||
+ | 361 | ||
+ | 362 | ||
+ | 363 | ||
+ | 364</pre></td><td><pre style="margin: 0; line-height: 125%"><span style="color: #8f5902; font-style: italic">#! /usr/bin/python3</span> | ||
+ | <span style="color: #8f5902; font-style: italic"># Simple udp socket server</span> | ||
+ | |||
+ | <span style="color: #204a87; font-weight: bold">import</span> <span style="color: #000000">calendar</span> | ||
+ | <span style="color: #204a87; font-weight: bold">import</span> <span style="color: #000000">datetime</span> | ||
+ | <span style="color: #204a87; font-weight: bold">import</span> <span style="color: #000000">logging</span> | ||
+ | <span style="color: #204a87; font-weight: bold">import</span> <span style="color: #000000">socket</span> | ||
+ | <span style="color: #204a87; font-weight: bold">import</span> <span style="color: #000000">sys</span> | ||
+ | <span style="color: #204a87; font-weight: bold">import</span> <span style="color: #000000">time</span> | ||
+ | |||
+ | <span style="color: #204a87; font-weight: bold">import</span> <span style="color: #000000">RPi.GPIO</span> <span style="color: #204a87; font-weight: bold">as</span> <span style="color: #000000">GPIO</span> | ||
+ | <span style="color: #204a87; font-weight: bold">import</span> <span style="color: #000000">serial</span> | ||
+ | <span style="color: #204a87; font-weight: bold">from</span> <span style="color: #000000">cam.colicam_master</span> <span style="color: #204a87; font-weight: bold">import</span> <span style="color: #000000">ColiCamMaster</span> | ||
+ | <span style="color: #204a87; font-weight: bold">from</span> <span style="color: #000000">cam.colicam_slave</span> <span style="color: #204a87; font-weight: bold">import</span> <span style="color: #000000">ColiCamSlave</span> | ||
+ | |||
+ | <span style="color: #204a87; font-weight: bold">from</span> <span style="color: #000000">w1thermsensor</span> <span style="color: #204a87; font-weight: bold">import</span> <span style="color: #000000">W1ThermSensor</span> | ||
+ | |||
+ | <span style="color: #8f5902; font-style: italic"># heater pins</span> | ||
+ | <span style="color: #000000">HEAT</span> <span style="color: #ce5c00; font-weight: bold">=</span> <span style="color: #0000cf; font-weight: bold">40</span> | ||
+ | |||
+ | <span style="color: #000000">PORT</span> <span style="color: #ce5c00; font-weight: bold">=</span> <span style="color: #0000cf; font-weight: bold">4343</span> <span style="color: #8f5902; font-style: italic"># Arbitrary non-privileged port</span> | ||
+ | <span style="color: #000000">HOST</span> <span style="color: #ce5c00; font-weight: bold">=</span> <span style="color: #4e9a06">"192.168.43.150"</span> | ||
+ | |||
+ | <span style="color: #8f5902; font-style: italic"># Messages</span> | ||
+ | <span style="color: #000000">OBSTACLE</span> <span style="color: #ce5c00; font-weight: bold">=</span> <span style="color: #4e9a06">'obstacle'</span> | ||
+ | <span style="color: #000000">CLEAR</span> <span style="color: #ce5c00; font-weight: bold">=</span> <span style="color: #4e9a06">'clear'</span> | ||
+ | <span style="color: #000000">HEATING_TEST</span> <span style="color: #ce5c00; font-weight: bold">=</span> <span style="color: #4e9a06">'heat'</span> | ||
+ | <span style="color: #000000">GET_TEMP</span> <span style="color: #ce5c00; font-weight: bold">=</span> <span style="color: #4e9a06">'temp'</span> | ||
+ | <span style="color: #000000">PUMP_1_TEST</span> <span style="color: #ce5c00; font-weight: bold">=</span> <span style="color: #4e9a06">'pump_1'</span> | ||
+ | <span style="color: #000000">CAM_TEST</span> <span style="color: #ce5c00; font-weight: bold">=</span> <span style="color: #4e9a06">'cam'</span> | ||
+ | <span style="color: #000000">TURN</span> <span style="color: #ce5c00; font-weight: bold">=</span> <span style="color: #4e9a06">'turn'</span> | ||
+ | <span style="color: #000000">DRIVE</span> <span style="color: #ce5c00; font-weight: bold">=</span> <span style="color: #4e9a06">'drive'</span> | ||
+ | |||
+ | <span style="color: #8f5902; font-style: italic"># heating</span> | ||
+ | <span style="color: #000000">HEATING</span> <span style="color: #ce5c00; font-weight: bold">=</span> <span style="color: #204a87; font-weight: bold">False</span> | ||
+ | <span style="color: #000000">TARGET_TEMP</span> <span style="color: #ce5c00; font-weight: bold">=</span> <span style="color: #0000cf; font-weight: bold">43</span> <span style="color: #8f5902; font-style: italic"># degrees</span> | ||
+ | <span style="color: #000000">INTERVALL</span> <span style="color: #ce5c00; font-weight: bold">=</span> <span style="color: #0000cf; font-weight: bold">8</span> <span style="color: #8f5902; font-style: italic"># seconds</span> | ||
+ | <span style="color: #000000">HEATING_PERIOD</span> <span style="color: #ce5c00; font-weight: bold">=</span> <span style="color: #0000cf; font-weight: bold">300</span> <span style="color: #8f5902; font-style: italic"># seconds</span> | ||
+ | <span style="color: #8f5902; font-style: italic"># pump</span> | ||
+ | <span style="color: #000000">PUMP_IVALL</span> <span style="color: #ce5c00; font-weight: bold">=</span> <span style="color: #0000cf; font-weight: bold">12</span> | ||
+ | |||
+ | <span style="color: #000000">DIFF_THRESHOLD</span> <span style="color: #ce5c00; font-weight: bold">=</span> <span style="color: #0000cf; font-weight: bold">12</span> | ||
+ | |||
+ | <span style="color: #000000">logger</span> <span style="color: #ce5c00; font-weight: bold">=</span> <span style="color: #000000">logging</span><span style="color: #ce5c00; font-weight: bold">.</span><span style="color: #000000">getLogger</span><span style="color: #000000; font-weight: bold">(</span><span style="color: #4e9a06">'colibot'</span><span style="color: #000000; font-weight: bold">)</span> | ||
+ | |||
+ | |||
+ | |||
+ | <span style="color: #204a87; font-weight: bold">def</span> <span style="color: #000000">get_temperature</span><span style="color: #000000; font-weight: bold">():</span> | ||
+ | <span style="color: #8f5902; font-style: italic">"""</span> | ||
+ | <span style="color: #8f5902; font-style: italic"> read temperature from sensor</span> | ||
+ | <span style="color: #8f5902; font-style: italic"> """</span> | ||
+ | <span style="color: #000000">sensor</span> <span style="color: #ce5c00; font-weight: bold">=</span> <span style="color: #000000">W1ThermSensor</span><span style="color: #000000; font-weight: bold">()</span> | ||
+ | <span style="color: #000000">temp_c</span> <span style="color: #ce5c00; font-weight: bold">=</span> <span style="color: #000000">sensor</span><span style="color: #ce5c00; font-weight: bold">.</span><span style="color: #000000">get_temperature</span><span style="color: #000000; font-weight: bold">()</span> | ||
+ | <span style="color: #204a87; font-weight: bold">return</span> <span style="color: #000000">temp_c</span> | ||
+ | |||
+ | |||
+ | <span style="color: #204a87; font-weight: bold">def</span> <span style="color: #000000">toggle_heating</span><span style="color: #000000; font-weight: bold">(</span><span style="color: #000000">heat</span><span style="color: #000000; font-weight: bold">):</span> | ||
+ | <span style="color: #8f5902; font-style: italic">"""</span> | ||
+ | <span style="color: #8f5902; font-style: italic"> GPIO 20 and 21</span> | ||
+ | <span style="color: #8f5902; font-style: italic"> HIGH = heating on</span> | ||
+ | <span style="color: #8f5902; font-style: italic"> LOW = heating off</span> | ||
+ | <span style="color: #8f5902; font-style: italic"> """</span> | ||
+ | <span style="color: #204a87; font-weight: bold">if</span> <span style="color: #000000">heat</span> <span style="color: #204a87; font-weight: bold">is</span> <span style="color: #204a87; font-weight: bold">False</span><span style="color: #000000; font-weight: bold">:</span> | ||
+ | <span style="color: #8f5902; font-style: italic">#logger.info("HEATING OFF")</span> | ||
+ | <span style="color: #000000">HEATING</span> <span style="color: #ce5c00; font-weight: bold">=</span> <span style="color: #204a87; font-weight: bold">False</span> | ||
+ | <span style="color: #000000">GPIO</span><span style="color: #ce5c00; font-weight: bold">.</span><span style="color: #000000">output</span><span style="color: #000000; font-weight: bold">(</span><span style="color: #000000">HEAT</span><span style="color: #000000; font-weight: bold">,</span> <span style="color: #0000cf; font-weight: bold">0</span><span style="color: #000000; font-weight: bold">)</span> | ||
+ | <span style="color: #204a87; font-weight: bold">else</span><span style="color: #000000; font-weight: bold">:</span> | ||
+ | <span style="color: #8f5902; font-style: italic">#logger.info("HEATING ON")</span> | ||
+ | <span style="color: #000000">HEATING</span> <span style="color: #ce5c00; font-weight: bold">=</span> <span style="color: #204a87; font-weight: bold">True</span> | ||
+ | <span style="color: #000000">GPIO</span><span style="color: #ce5c00; font-weight: bold">.</span><span style="color: #000000">output</span><span style="color: #000000; font-weight: bold">(</span><span style="color: #000000">HEAT</span><span style="color: #000000; font-weight: bold">,</span> <span style="color: #0000cf; font-weight: bold">1</span><span style="color: #000000; font-weight: bold">)</span> | ||
+ | |||
+ | |||
+ | <span style="color: #204a87; font-weight: bold">def</span> <span style="color: #000000">start_heating</span><span style="color: #000000; font-weight: bold">():</span> | ||
+ | <span style="color: #8f5902; font-style: italic">"""</span> | ||
+ | <span style="color: #8f5902; font-style: italic"> """</span> | ||
+ | <span style="color: #000000">logger</span><span style="color: #ce5c00; font-weight: bold">.</span><span style="color: #000000">info</span><span style="color: #000000; font-weight: bold">(</span><span style="color: #4e9a06">"*** Entering heating loop ..."</span><span style="color: #000000; font-weight: bold">)</span> | ||
+ | |||
+ | <span style="color: #204a87; font-weight: bold">while</span><span style="color: #000000; font-weight: bold">(</span><span style="color: #0000cf; font-weight: bold">1</span><span style="color: #000000; font-weight: bold">):</span> | ||
+ | <span style="color: #000000">temp</span> <span style="color: #ce5c00; font-weight: bold">=</span> <span style="color: #000000">get_temperature</span><span style="color: #000000; font-weight: bold">()</span> | ||
+ | <span style="color: #000000">logger</span><span style="color: #ce5c00; font-weight: bold">.</span><span style="color: #000000">info</span><span style="color: #000000; font-weight: bold">(</span><span style="color: #4e9a06">"*** Current temperature: "</span> <span style="color: #ce5c00; font-weight: bold">+</span> <span style="color: #204a87">str</span><span style="color: #000000; font-weight: bold">(</span><span style="color: #000000">temp</span><span style="color: #000000; font-weight: bold">))</span> | ||
+ | <span style="color: #204a87; font-weight: bold">if</span> <span style="color: #000000">temp</span> <span style="color: #ce5c00; font-weight: bold">>=</span> <span style="color: #000000; font-weight: bold">(</span><span style="color: #000000">TARGET_TEMP</span> <span style="color: #ce5c00; font-weight: bold">-</span> <span style="color: #0000cf; font-weight: bold">2</span><span style="color: #000000; font-weight: bold">):</span> | ||
+ | <span style="color: #000000">logger</span><span style="color: #ce5c00; font-weight: bold">.</span><span style="color: #000000">info</span><span style="color: #000000; font-weight: bold">(</span><span style="color: #4e9a06">"*** TARGET_TEMP reached!"</span><span style="color: #000000; font-weight: bold">)</span> | ||
+ | <span style="color: #204a87; font-weight: bold">break</span><span style="color: #000000; font-weight: bold">;</span> | ||
+ | <span style="color: #000000">toggle_heating</span><span style="color: #000000; font-weight: bold">(</span><span style="color: #204a87; font-weight: bold">True</span><span style="color: #000000; font-weight: bold">)</span> | ||
+ | <span style="color: #000000">time</span><span style="color: #ce5c00; font-weight: bold">.</span><span style="color: #000000">sleep</span><span style="color: #000000; font-weight: bold">(</span><span style="color: #0000cf; font-weight: bold">15</span><span style="color: #000000; font-weight: bold">)</span> | ||
+ | <span style="color: #000000">toggle_heating</span><span style="color: #000000; font-weight: bold">(</span><span style="color: #204a87; font-weight: bold">False</span><span style="color: #000000; font-weight: bold">)</span> | ||
+ | |||
+ | <span style="color: #000000">heating_time</span> <span style="color: #ce5c00; font-weight: bold">=</span> <span style="color: #000000">HEATING_PERIOD</span> <span style="color: #8f5902; font-style: italic"># seconds</span> | ||
+ | <span style="color: #000000">start</span> <span style="color: #ce5c00; font-weight: bold">=</span> <span style="color: #000000">calendar</span><span style="color: #ce5c00; font-weight: bold">.</span><span style="color: #000000">timegm</span><span style="color: #000000; font-weight: bold">(</span><span style="color: #000000">time</span><span style="color: #ce5c00; font-weight: bold">.</span><span style="color: #000000">gmtime</span><span style="color: #000000; font-weight: bold">())</span> | ||
+ | <span style="color: #000000">end</span> <span style="color: #ce5c00; font-weight: bold">=</span> <span style="color: #000000">start</span> <span style="color: #ce5c00; font-weight: bold">+</span> <span style="color: #000000">heating_time</span> | ||
+ | <span style="color: #000000">logger</span><span style="color: #ce5c00; font-weight: bold">.</span><span style="color: #000000">info</span><span style="color: #000000; font-weight: bold">(</span><span style="color: #4e9a06">"*** activation period, keeping target temp for 5 mins:"</span><span style="color: #000000; font-weight: bold">)</span> | ||
+ | <span style="color: #000000">remaining_time</span> <span style="color: #ce5c00; font-weight: bold">=</span> <span style="color: #000000">heating_time</span> | ||
+ | |||
+ | <span style="color: #204a87; font-weight: bold">while</span><span style="color: #000000; font-weight: bold">(</span><span style="color: #0000cf; font-weight: bold">1</span><span style="color: #000000; font-weight: bold">):</span> | ||
+ | <span style="color: #8f5902; font-style: italic"># logger.info("minutes left: "+str( (end - calendar.timegm(time.gmtime()))/60 ) )</span> | ||
+ | <span style="color: #204a87; font-weight: bold">if</span> <span style="color: #000000">calendar</span><span style="color: #ce5c00; font-weight: bold">.</span><span style="color: #000000">timegm</span><span style="color: #000000; font-weight: bold">(</span><span style="color: #000000">time</span><span style="color: #ce5c00; font-weight: bold">.</span><span style="color: #000000">gmtime</span><span style="color: #000000; font-weight: bold">())</span> <span style="color: #ce5c00; font-weight: bold">>=</span> <span style="color: #000000">end</span><span style="color: #000000; font-weight: bold">:</span> | ||
+ | <span style="color: #204a87; font-weight: bold">break</span> | ||
+ | |||
+ | <span style="color: #000000">temp</span> <span style="color: #ce5c00; font-weight: bold">=</span> <span style="color: #000000">get_temperature</span><span style="color: #000000; font-weight: bold">()</span> | ||
+ | |||
+ | <span style="color: #8f5902; font-style: italic"># logger.info("-->")</span> | ||
+ | <span style="color: #000000">logger</span><span style="color: #ce5c00; font-weight: bold">.</span><span style="color: #000000">info</span><span style="color: #000000; font-weight: bold">(</span><span style="color: #4e9a06">"*** Current temperature: "</span> <span style="color: #ce5c00; font-weight: bold">+</span> <span style="color: #204a87">str</span><span style="color: #000000; font-weight: bold">(</span><span style="color: #000000">temp</span><span style="color: #000000; font-weight: bold">))</span> | ||
+ | |||
+ | <span style="color: #204a87; font-weight: bold">if</span> <span style="color: #000000">temp</span> <span style="color: #ce5c00; font-weight: bold">>=</span> <span style="color: #000000; font-weight: bold">(</span><span style="color: #000000">TARGET_TEMP</span> <span style="color: #000000; font-weight: bold">):</span> | ||
+ | <span style="color: #000000">time</span><span style="color: #ce5c00; font-weight: bold">.</span><span style="color: #000000">sleep</span><span style="color: #000000; font-weight: bold">(</span><span style="color: #0000cf; font-weight: bold">10</span><span style="color: #000000; font-weight: bold">)</span> | ||
+ | <span style="color: #204a87; font-weight: bold">elif</span><span style="color: #000000; font-weight: bold">(</span> <span style="color: #000000">temp</span> <span style="color: #ce5c00; font-weight: bold"><</span> <span style="color: #000000">TARGET_TEMP</span> <span style="color: #000000; font-weight: bold">):</span> | ||
+ | <span style="color: #8f5902; font-style: italic"># logger.info("*** heating ...")</span> | ||
+ | <span style="color: #000000">toggle_heating</span><span style="color: #000000; font-weight: bold">(</span><span style="color: #204a87; font-weight: bold">True</span><span style="color: #000000; font-weight: bold">)</span> | ||
+ | <span style="color: #000000">time</span><span style="color: #ce5c00; font-weight: bold">.</span><span style="color: #000000">sleep</span><span style="color: #000000; font-weight: bold">(</span><span style="color: #0000cf; font-weight: bold">5</span><span style="color: #000000; font-weight: bold">)</span> | ||
+ | <span style="color: #000000">toggle_heating</span><span style="color: #000000; font-weight: bold">(</span><span style="color: #204a87; font-weight: bold">False</span><span style="color: #000000; font-weight: bold">)</span> | ||
+ | |||
+ | <span style="color: #8f5902; font-style: italic">#if remaining_time % 60 == 0:</span> | ||
+ | <span style="color: #000000">logger</span><span style="color: #ce5c00; font-weight: bold">.</span><span style="color: #000000">info</span><span style="color: #000000; font-weight: bold">(</span><span style="color: #4e9a06">"> {} mins remaining."</span><span style="color: #ce5c00; font-weight: bold">.</span><span style="color: #000000">format</span><span style="color: #000000; font-weight: bold">(</span> <span style="color: #000000">remaining_time</span> <span style="color: #ce5c00; font-weight: bold">/</span> <span style="color: #0000cf; font-weight: bold">60</span> <span style="color: #000000; font-weight: bold">))</span> | ||
+ | |||
+ | <span style="color: #000000">time</span><span style="color: #ce5c00; font-weight: bold">.</span><span style="color: #000000">sleep</span><span style="color: #000000; font-weight: bold">(</span><span style="color: #0000cf; font-weight: bold">5</span><span style="color: #000000; font-weight: bold">)</span> | ||
+ | <span style="color: #000000">remaining_time</span> <span style="color: #ce5c00; font-weight: bold">-=</span> <span style="color: #0000cf; font-weight: bold">14</span> | ||
+ | |||
+ | |||
+ | <span style="color: #204a87; font-weight: bold">def</span> <span style="color: #000000">start_pump</span><span style="color: #000000; font-weight: bold">(</span><span style="color: #000000">pwms</span><span style="color: #000000; font-weight: bold">,</span> <span style="color: #000000">seconds</span><span style="color: #000000; font-weight: bold">):</span> | ||
+ | <span style="color: #8f5902; font-style: italic">"""</span> | ||
+ | <span style="color: #8f5902; font-style: italic"> pump_1:</span> | ||
+ | <span style="color: #8f5902; font-style: italic"> pwms[0](11, 180)</span> | ||
+ | <span style="color: #8f5902; font-style: italic"> pin 13 </span> | ||
+ | <span style="color: #8f5902; font-style: italic"> pin 15 </span> | ||
+ | <span style="color: #8f5902; font-style: italic"> </span> | ||
+ | <span style="color: #8f5902; font-style: italic"> pump_2:</span> | ||
+ | <span style="color: #8f5902; font-style: italic"> pwms[1](19, 180)</span> | ||
+ | <span style="color: #8f5902; font-style: italic"> pin 21</span> | ||
+ | <span style="color: #8f5902; font-style: italic"> pin 23</span> | ||
+ | <span style="color: #8f5902; font-style: italic"> --> ~1ml per second </span> | ||
+ | <span style="color: #8f5902; font-style: italic"> """</span> | ||
+ | <span style="color: #000000">logger</span><span style="color: #ce5c00; font-weight: bold">.</span><span style="color: #000000">info</span><span style="color: #000000; font-weight: bold">(</span><span style="color: #4e9a06">"*** Starting pumps for {} seconds."</span><span style="color: #ce5c00; font-weight: bold">.</span><span style="color: #000000">format</span><span style="color: #000000; font-weight: bold">(</span><span style="color: #204a87">str</span><span style="color: #000000; font-weight: bold">(</span><span style="color: #000000">seconds</span><span style="color: #000000; font-weight: bold">)))</span> | ||
+ | <span style="color: #000000">pwms</span><span style="color: #000000; font-weight: bold">[</span><span style="color: #0000cf; font-weight: bold">0</span><span style="color: #000000; font-weight: bold">]</span><span style="color: #ce5c00; font-weight: bold">.</span><span style="color: #000000">start</span><span style="color: #000000; font-weight: bold">(</span><span style="color: #0000cf; font-weight: bold">100</span><span style="color: #000000; font-weight: bold">)</span> <span style="color: #8f5902; font-style: italic"># out</span> | ||
+ | <span style="color: #000000">pwms</span><span style="color: #000000; font-weight: bold">[</span><span style="color: #0000cf; font-weight: bold">1</span><span style="color: #000000; font-weight: bold">]</span><span style="color: #ce5c00; font-weight: bold">.</span><span style="color: #000000">start</span><span style="color: #000000; font-weight: bold">(</span><span style="color: #0000cf; font-weight: bold">100</span><span style="color: #000000; font-weight: bold">)</span> <span style="color: #8f5902; font-style: italic"># in</span> | ||
+ | |||
+ | <span style="color: #000000">time</span><span style="color: #ce5c00; font-weight: bold">.</span><span style="color: #000000">sleep</span><span style="color: #000000; font-weight: bold">(</span><span style="color: #000000">seconds</span><span style="color: #000000; font-weight: bold">)</span> | ||
+ | <span style="color: #000000">logger</span><span style="color: #ce5c00; font-weight: bold">.</span><span style="color: #000000">info</span><span style="color: #000000; font-weight: bold">(</span><span style="color: #4e9a06">"*** Stopping pumps"</span><span style="color: #000000; font-weight: bold">)</span> | ||
+ | <span style="color: #000000">pwms</span><span style="color: #000000; font-weight: bold">[</span><span style="color: #0000cf; font-weight: bold">0</span><span style="color: #000000; font-weight: bold">]</span><span style="color: #ce5c00; font-weight: bold">.</span><span style="color: #000000">stop</span><span style="color: #000000; font-weight: bold">()</span> | ||
+ | <span style="color: #000000">pwms</span><span style="color: #000000; font-weight: bold">[</span><span style="color: #0000cf; font-weight: bold">1</span><span style="color: #000000; font-weight: bold">]</span><span style="color: #ce5c00; font-weight: bold">.</span><span style="color: #000000">stop</span><span style="color: #000000; font-weight: bold">()</span> | ||
+ | |||
+ | |||
+ | |||
+ | |||
+ | |||
+ | <span style="color: #204a87; font-weight: bold">def</span> <span style="color: #000000">take_measure</span><span style="color: #000000; font-weight: bold">():</span> | ||
+ | <span style="color: #000000">logger</span><span style="color: #ce5c00; font-weight: bold">.</span><span style="color: #000000">info</span><span style="color: #000000; font-weight: bold">(</span><span style="color: #4e9a06">"*** Measuring ..."</span><span style="color: #000000; font-weight: bold">)</span> | ||
+ | <span style="color: #000000">result</span> <span style="color: #ce5c00; font-weight: bold">=</span> <span style="color: #000000">cam</span><span style="color: #ce5c00; font-weight: bold">.</span><span style="color: #000000">measure</span><span style="color: #000000; font-weight: bold">()</span> | ||
+ | <span style="color: #204a87; font-weight: bold">return</span> <span style="color: #000000">result</span><span style="color: #000000; font-weight: bold">;</span> | ||
+ | |||
+ | <span style="color: #204a87; font-weight: bold">def</span> <span style="color: #000000">diff_results</span><span style="color: #000000; font-weight: bold">(</span><span style="color: #000000">bl</span><span style="color: #000000; font-weight: bold">,</span> <span style="color: #000000">m</span><span style="color: #000000; font-weight: bold">):</span> | ||
+ | <span style="color: #000000">r_diff</span> <span style="color: #ce5c00; font-weight: bold">=</span> <span style="color: #204a87">abs</span><span style="color: #000000; font-weight: bold">(</span><span style="color: #000000">bl</span><span style="color: #000000; font-weight: bold">[</span><span style="color: #0000cf; font-weight: bold">0</span><span style="color: #000000; font-weight: bold">]</span> <span style="color: #ce5c00; font-weight: bold">-</span> <span style="color: #000000">m</span><span style="color: #000000; font-weight: bold">[</span><span style="color: #0000cf; font-weight: bold">0</span><span style="color: #000000; font-weight: bold">])</span> | ||
+ | <span style="color: #000000">g_diff</span> <span style="color: #ce5c00; font-weight: bold">=</span> <span style="color: #204a87">abs</span><span style="color: #000000; font-weight: bold">(</span><span style="color: #000000">bl</span><span style="color: #000000; font-weight: bold">[</span><span style="color: #0000cf; font-weight: bold">1</span><span style="color: #000000; font-weight: bold">]</span> <span style="color: #ce5c00; font-weight: bold">-</span> <span style="color: #000000">m</span><span style="color: #000000; font-weight: bold">[</span><span style="color: #0000cf; font-weight: bold">1</span><span style="color: #000000; font-weight: bold">])</span> | ||
+ | <span style="color: #000000">b_diff</span> <span style="color: #ce5c00; font-weight: bold">=</span> <span style="color: #204a87">abs</span><span style="color: #000000; font-weight: bold">(</span><span style="color: #000000">bl</span><span style="color: #000000; font-weight: bold">[</span><span style="color: #0000cf; font-weight: bold">2</span><span style="color: #000000; font-weight: bold">]</span> <span style="color: #ce5c00; font-weight: bold">-</span> <span style="color: #000000">m</span><span style="color: #000000; font-weight: bold">[</span><span style="color: #0000cf; font-weight: bold">2</span><span style="color: #000000; font-weight: bold">])</span> | ||
+ | |||
+ | <span style="color: #000000">diff</span> <span style="color: #ce5c00; font-weight: bold">=</span> <span style="color: #000000">r_diff</span> <span style="color: #ce5c00; font-weight: bold">+</span> <span style="color: #000000">g_diff</span> <span style="color: #ce5c00; font-weight: bold">+</span> <span style="color: #000000">b_diff</span> | ||
+ | <span style="color: #000000">logger</span><span style="color: #ce5c00; font-weight: bold">.</span><span style="color: #000000">info</span><span style="color: #000000; font-weight: bold">(</span><span style="color: #4e9a06">"*** Diff_results: r_diff={} g_diff={} b_diff={}"</span><span style="color: #ce5c00; font-weight: bold">.</span><span style="color: #000000">format</span><span style="color: #000000; font-weight: bold">(</span><span style="color: #000000">r_diff</span><span style="color: #000000; font-weight: bold">,</span> <span style="color: #000000">g_diff</span><span style="color: #000000; font-weight: bold">,</span> <span style="color: #000000">b_diff</span><span style="color: #000000; font-weight: bold">))</span> | ||
+ | <span style="color: #000000">logger</span><span style="color: #ce5c00; font-weight: bold">.</span><span style="color: #000000">info</span><span style="color: #000000; font-weight: bold">(</span><span style="color: #4e9a06">"*** total: {}"</span><span style="color: #ce5c00; font-weight: bold">.</span><span style="color: #000000">format</span><span style="color: #000000; font-weight: bold">(</span><span style="color: #000000">diff</span><span style="color: #000000; font-weight: bold">))</span> | ||
+ | <span style="color: #204a87; font-weight: bold">if</span><span style="color: #000000; font-weight: bold">(</span><span style="color: #000000">diff</span> <span style="color: #ce5c00; font-weight: bold">>=</span> <span style="color: #000000">DIFF_THRESHOLD</span><span style="color: #000000; font-weight: bold">):</span> | ||
+ | <span style="color: #204a87; font-weight: bold">return</span> <span style="color: #204a87; font-weight: bold">True</span> | ||
+ | <span style="color: #204a87; font-weight: bold">else</span><span style="color: #000000; font-weight: bold">:</span> | ||
+ | <span style="color: #204a87; font-weight: bold">return</span> <span style="color: #204a87; font-weight: bold">False</span> | ||
+ | |||
+ | |||
+ | <span style="color: #204a87; font-weight: bold">def</span> <span style="color: #000000">create_socket</span><span style="color: #000000; font-weight: bold">():</span> | ||
+ | <span style="color: #8f5902; font-style: italic"># Datagram (udp) socket</span> | ||
+ | <span style="color: #204a87; font-weight: bold">try</span><span style="color: #000000; font-weight: bold">:</span> | ||
+ | <span style="color: #000000">sock</span> <span style="color: #ce5c00; font-weight: bold">=</span> <span style="color: #000000">socket</span><span style="color: #ce5c00; font-weight: bold">.</span><span style="color: #000000">socket</span><span style="color: #000000; font-weight: bold">(</span><span style="color: #000000">socket</span><span style="color: #ce5c00; font-weight: bold">.</span><span style="color: #000000">AF_INET</span><span style="color: #000000; font-weight: bold">,</span> <span style="color: #000000">socket</span><span style="color: #ce5c00; font-weight: bold">.</span><span style="color: #000000">SOCK_DGRAM</span><span style="color: #000000; font-weight: bold">)</span> | ||
+ | <span style="color: #000000">logger</span><span style="color: #ce5c00; font-weight: bold">.</span><span style="color: #000000">info</span><span style="color: #000000; font-weight: bold">(</span><span style="color: #4e9a06">'Socket created'</span><span style="color: #000000; font-weight: bold">)</span> | ||
+ | <span style="color: #204a87; font-weight: bold">except</span> <span style="color: #000000">socket</span><span style="color: #ce5c00; font-weight: bold">.</span><span style="color: #000000">error</span> <span style="color: #204a87; font-weight: bold">as</span> <span style="color: #000000">msg</span><span style="color: #000000; font-weight: bold">:</span> | ||
+ | <span style="color: #000000">logger</span><span style="color: #ce5c00; font-weight: bold">.</span><span style="color: #000000">error</span><span style="color: #000000; font-weight: bold">(</span><span style="color: #4e9a06">'Failed to create socket.'</span><span style="color: #000000; font-weight: bold">)</span> | ||
+ | <span style="color: #000000">GPIO</span><span style="color: #ce5c00; font-weight: bold">.</span><span style="color: #000000">cleanup</span><span style="color: #000000; font-weight: bold">()</span> | ||
+ | <span style="color: #000000">sys</span><span style="color: #ce5c00; font-weight: bold">.</span><span style="color: #000000">exit</span><span style="color: #000000; font-weight: bold">()</span> | ||
+ | |||
+ | <span style="color: #8f5902; font-style: italic"># Bind socket to local host and port</span> | ||
+ | <span style="color: #204a87; font-weight: bold">try</span><span style="color: #000000; font-weight: bold">:</span> | ||
+ | <span style="color: #000000">sock</span><span style="color: #ce5c00; font-weight: bold">.</span><span style="color: #000000">bind</span><span style="color: #000000; font-weight: bold">((</span><span style="color: #000000">HOST</span><span style="color: #000000; font-weight: bold">,</span> <span style="color: #000000">PORT</span><span style="color: #000000; font-weight: bold">))</span> | ||
+ | <span style="color: #204a87; font-weight: bold">except</span> <span style="color: #000000">socket</span><span style="color: #ce5c00; font-weight: bold">.</span><span style="color: #000000">error</span> <span style="color: #204a87; font-weight: bold">as</span> <span style="color: #000000">msg</span><span style="color: #000000; font-weight: bold">:</span> | ||
+ | <span style="color: #000000">logger</span><span style="color: #ce5c00; font-weight: bold">.</span><span style="color: #000000">error</span><span style="color: #000000; font-weight: bold">(</span><span style="color: #4e9a06">'Bind failed. '</span><span style="color: #000000; font-weight: bold">)</span> | ||
+ | <span style="color: #000000">GPIO</span><span style="color: #ce5c00; font-weight: bold">.</span><span style="color: #000000">cleanup</span><span style="color: #000000; font-weight: bold">()</span> | ||
+ | <span style="color: #000000">sys</span><span style="color: #ce5c00; font-weight: bold">.</span><span style="color: #000000">exit</span><span style="color: #000000; font-weight: bold">()</span> | ||
+ | |||
+ | <span style="color: #000000">logger</span><span style="color: #ce5c00; font-weight: bold">.</span><span style="color: #000000">info</span><span style="color: #000000; font-weight: bold">(</span><span style="color: #4e9a06">'Socket bind complete'</span><span style="color: #000000; font-weight: bold">)</span> | ||
+ | |||
+ | <span style="color: #204a87; font-weight: bold">return</span> <span style="color: #000000">sock</span> | ||
+ | |||
+ | |||
+ | <span style="color: #204a87; font-weight: bold">def</span> <span style="color: #000000">start_listening</span><span style="color: #000000; font-weight: bold">(</span><span style="color: #000000">sock</span><span style="color: #000000; font-weight: bold">,</span> <span style="color: #000000">pwms</span><span style="color: #000000; font-weight: bold">):</span> | ||
+ | <span style="color: #8f5902; font-style: italic"># now keep talking with the client</span> | ||
+ | <span style="color: #204a87; font-weight: bold">try</span><span style="color: #000000; font-weight: bold">:</span> | ||
+ | <span style="color: #204a87; font-weight: bold">while</span> <span style="color: #0000cf; font-weight: bold">1</span><span style="color: #000000; font-weight: bold">:</span> | ||
+ | <span style="color: #8f5902; font-style: italic"># receive data from client (data, addr)</span> | ||
+ | <span style="color: #000000">rec</span> <span style="color: #ce5c00; font-weight: bold">=</span> <span style="color: #000000">sock</span><span style="color: #ce5c00; font-weight: bold">.</span><span style="color: #000000">recvfrom</span><span style="color: #000000; font-weight: bold">(</span><span style="color: #0000cf; font-weight: bold">1024</span><span style="color: #000000; font-weight: bold">)</span> | ||
+ | <span style="color: #000000">data</span> <span style="color: #ce5c00; font-weight: bold">=</span> <span style="color: #000000">rec</span><span style="color: #000000; font-weight: bold">[</span><span style="color: #0000cf; font-weight: bold">0</span><span style="color: #000000; font-weight: bold">]</span> | ||
+ | <span style="color: #000000">addr</span> <span style="color: #ce5c00; font-weight: bold">=</span> <span style="color: #000000">rec</span><span style="color: #000000; font-weight: bold">[</span><span style="color: #0000cf; font-weight: bold">1</span><span style="color: #000000; font-weight: bold">]</span> | ||
+ | |||
+ | <span style="color: #000000">logger</span><span style="color: #ce5c00; font-weight: bold">.</span><span style="color: #000000">info</span><span style="color: #000000; font-weight: bold">(</span><span style="color: #4e9a06">"***"</span><span style="color: #000000; font-weight: bold">)</span> | ||
+ | |||
+ | <span style="color: #204a87; font-weight: bold">if</span> <span style="color: #000000">data</span><span style="color: #ce5c00; font-weight: bold">.</span><span style="color: #000000">decode</span><span style="color: #000000; font-weight: bold">(</span><span style="color: #4e9a06">"utf-8"</span><span style="color: #000000; font-weight: bold">)</span> <span style="color: #ce5c00; font-weight: bold">==</span> <span style="color: #000000">OBSTACLE</span><span style="color: #000000; font-weight: bold">:</span> <span style="color: #8f5902; font-style: italic"># 'obstacle'</span> | ||
+ | <span style="color: #000000">logger</span><span style="color: #ce5c00; font-weight: bold">.</span><span style="color: #000000">info</span><span style="color: #000000; font-weight: bold">(</span> | ||
+ | <span style="color: #4e9a06">"recieved OBSTACLE: requesting colis and heating them to TARGET_TEMP..."</span><span style="color: #000000; font-weight: bold">)</span> | ||
+ | |||
+ | <span style="color: #8f5902; font-style: italic"># wait for some time to cool of heating chamber</span> | ||
+ | <span style="color: #000000">cooldown</span> <span style="color: #ce5c00; font-weight: bold">=</span> <span style="color: #0000cf; font-weight: bold">180</span> | ||
+ | <span style="color: #000000">logger</span><span style="color: #ce5c00; font-weight: bold">.</span><span style="color: #000000">info</span><span style="color: #000000; font-weight: bold">(</span><span style="color: #4e9a06">"Waiting {} to cool chamber."</span><span style="color: #ce5c00; font-weight: bold">.</span><span style="color: #000000">format</span><span style="color: #000000; font-weight: bold">(</span><span style="color: #000000">cooldown</span><span style="color: #ce5c00; font-weight: bold">/</span><span style="color: #0000cf; font-weight: bold">60</span><span style="color: #000000; font-weight: bold">))</span> | ||
+ | <span style="color: #000000">time</span><span style="color: #ce5c00; font-weight: bold">.</span><span style="color: #000000">sleep</span><span style="color: #000000; font-weight: bold">(</span><span style="color: #000000">cooldown</span><span style="color: #000000; font-weight: bold">)</span> | ||
+ | |||
+ | |||
+ | <span style="color: #8f5902; font-style: italic"># fill chamber for baseline measureing</span> | ||
+ | <span style="color: #000000">start_pump</span><span style="color: #000000; font-weight: bold">(</span><span style="color: #000000">pwms</span><span style="color: #000000; font-weight: bold">,</span> <span style="color: #000000">PUMP_IVALL</span><span style="color: #000000; font-weight: bold">)</span> | ||
+ | |||
+ | <span style="color: #8f5902; font-style: italic"># baseline</span> | ||
+ | <span style="color: #000000">baseline</span> <span style="color: #ce5c00; font-weight: bold">=</span> <span style="color: #000000">take_measure</span><span style="color: #000000; font-weight: bold">()</span> | ||
+ | <span style="color: #000000">logger</span><span style="color: #ce5c00; font-weight: bold">.</span><span style="color: #000000">info</span><span style="color: #000000; font-weight: bold">(</span><span style="color: #4e9a06">"baseline values: r{}, g{}, b{}"</span><span style="color: #ce5c00; font-weight: bold">.</span><span style="color: #000000">format</span><span style="color: #000000; font-weight: bold">(</span><span style="color: #000000">baseline</span><span style="color: #000000; font-weight: bold">[</span><span style="color: #0000cf; font-weight: bold">0</span><span style="color: #000000; font-weight: bold">],</span> <span style="color: #000000">baseline</span><span style="color: #000000; font-weight: bold">[</span><span style="color: #0000cf; font-weight: bold">1</span><span style="color: #000000; font-weight: bold">],</span> <span style="color: #000000">baseline</span><span style="color: #000000; font-weight: bold">[</span><span style="color: #0000cf; font-weight: bold">2</span><span style="color: #000000; font-weight: bold">]))</span> | ||
+ | |||
+ | <span style="color: #000000">start_heating</span><span style="color: #000000; font-weight: bold">()</span> | ||
+ | |||
+ | <span style="color: #8f5902; font-style: italic"># activated to chamber</span> | ||
+ | <span style="color: #000000">start_pump</span><span style="color: #000000; font-weight: bold">(</span><span style="color: #000000">pwms</span><span style="color: #000000; font-weight: bold">,</span> <span style="color: #0000cf; font-weight: bold">5</span><span style="color: #000000; font-weight: bold">)</span> | ||
+ | |||
+ | <span style="color: #000000">logger</span><span style="color: #ce5c00; font-weight: bold">.</span><span style="color: #000000">info</span><span style="color: #000000; font-weight: bold">(</span><span style="color: #4e9a06">"... start analyzing"</span><span style="color: #000000; font-weight: bold">)</span> | ||
+ | <span style="color: #000000">measurement</span> <span style="color: #ce5c00; font-weight: bold">=</span> <span style="color: #000000">take_measure</span><span style="color: #000000; font-weight: bold">()</span> | ||
+ | |||
+ | <span style="color: #204a87; font-weight: bold">if</span> <span style="color: #000000; font-weight: bold">(</span><span style="color: #000000">diff_results</span><span style="color: #000000; font-weight: bold">(</span><span style="color: #000000">baseline</span><span style="color: #000000; font-weight: bold">,</span> <span style="color: #000000">measurement</span><span style="color: #000000; font-weight: bold">)</span> <span style="color: #204a87; font-weight: bold">is</span> <span style="color: #204a87; font-weight: bold">True</span><span style="color: #000000; font-weight: bold">):</span> | ||
+ | <span style="color: #000000">logger</span><span style="color: #ce5c00; font-weight: bold">.</span><span style="color: #000000">info</span><span style="color: #000000; font-weight: bold">(</span><span style="color: #4e9a06">" TURN !!."</span><span style="color: #000000; font-weight: bold">)</span> | ||
+ | <span style="color: #000000">reply</span> <span style="color: #ce5c00; font-weight: bold">=</span> <span style="color: #4e9a06">'turn'</span> | ||
+ | <span style="color: #204a87; font-weight: bold">else</span><span style="color: #000000; font-weight: bold">:</span> | ||
+ | <span style="color: #000000">logger</span><span style="color: #ce5c00; font-weight: bold">.</span><span style="color: #000000">info</span><span style="color: #000000; font-weight: bold">(</span><span style="color: #4e9a06">" DRIVE !!."</span><span style="color: #000000; font-weight: bold">)</span> | ||
+ | <span style="color: #000000">reply</span> <span style="color: #ce5c00; font-weight: bold">=</span> <span style="color: #4e9a06">'drive'</span> | ||
+ | |||
+ | |||
+ | <span style="color: #204a87; font-weight: bold">elif</span> <span style="color: #000000">data</span><span style="color: #ce5c00; font-weight: bold">.</span><span style="color: #000000">decode</span><span style="color: #000000; font-weight: bold">(</span><span style="color: #4e9a06">"utf-8"</span><span style="color: #000000; font-weight: bold">)</span> <span style="color: #ce5c00; font-weight: bold">==</span> <span style="color: #000000">CLEAR</span><span style="color: #000000; font-weight: bold">:</span> <span style="color: #8f5902; font-style: italic"># 'clear'</span> | ||
+ | <span style="color: #000000">logger</span><span style="color: #ce5c00; font-weight: bold">.</span><span style="color: #000000">info</span><span style="color: #000000; font-weight: bold">(</span><span style="color: #4e9a06">"recieved CLEAR: requesting colis and start analyzing."</span><span style="color: #000000; font-weight: bold">)</span> | ||
+ | <span style="color: #8f5902; font-style: italic"># wait for some time to cool of heating chamber</span> | ||
+ | <span style="color: #000000">cooldown</span> <span style="color: #ce5c00; font-weight: bold">=</span> <span style="color: #0000cf; font-weight: bold">180</span> | ||
+ | <span style="color: #000000">logger</span><span style="color: #ce5c00; font-weight: bold">.</span><span style="color: #000000">info</span><span style="color: #000000; font-weight: bold">(</span><span style="color: #4e9a06">"Waiting {} to cool chamber."</span><span style="color: #ce5c00; font-weight: bold">.</span><span style="color: #000000">format</span><span style="color: #000000; font-weight: bold">(</span><span style="color: #000000">cooldown</span><span style="color: #ce5c00; font-weight: bold">/</span><span style="color: #0000cf; font-weight: bold">60</span><span style="color: #000000; font-weight: bold">))</span> | ||
+ | <span style="color: #000000">time</span><span style="color: #ce5c00; font-weight: bold">.</span><span style="color: #000000">sleep</span><span style="color: #000000; font-weight: bold">(</span><span style="color: #000000">cooldown</span><span style="color: #000000; font-weight: bold">)</span> | ||
+ | <span style="color: #8f5902; font-style: italic"># fill chamber for baseline measureing</span> | ||
+ | <span style="color: #000000">start_pump</span><span style="color: #000000; font-weight: bold">(</span><span style="color: #000000">pwms</span><span style="color: #000000; font-weight: bold">,</span> <span style="color: #000000">PUMP_IVALL</span><span style="color: #000000; font-weight: bold">)</span> | ||
+ | <span style="color: #8f5902; font-style: italic"># baseline</span> | ||
+ | <span style="color: #000000">baseline</span> <span style="color: #ce5c00; font-weight: bold">=</span> <span style="color: #000000">take_measure</span><span style="color: #000000; font-weight: bold">()</span> | ||
+ | <span style="color: #000000">logger</span><span style="color: #ce5c00; font-weight: bold">.</span><span style="color: #000000">info</span><span style="color: #000000; font-weight: bold">(</span><span style="color: #4e9a06">"baseline values: r{}, g{}, b{}"</span><span style="color: #ce5c00; font-weight: bold">.</span><span style="color: #000000">format</span><span style="color: #000000; font-weight: bold">(</span><span style="color: #000000">baseline</span><span style="color: #000000; font-weight: bold">[</span><span style="color: #0000cf; font-weight: bold">0</span><span style="color: #000000; font-weight: bold">],</span> <span style="color: #000000">baseline</span><span style="color: #000000; font-weight: bold">[</span><span style="color: #0000cf; font-weight: bold">1</span><span style="color: #000000; font-weight: bold">],</span> <span style="color: #000000">baseline</span><span style="color: #000000; font-weight: bold">[</span><span style="color: #0000cf; font-weight: bold">2</span><span style="color: #000000; font-weight: bold">]))</span> | ||
+ | |||
+ | <span style="color: #000000">logger</span><span style="color: #ce5c00; font-weight: bold">.</span><span style="color: #000000">info</span><span style="color: #000000; font-weight: bold">(</span><span style="color: #4e9a06">"waiting loop: {} minutes."</span><span style="color: #ce5c00; font-weight: bold">.</span><span style="color: #000000">format</span><span style="color: #000000; font-weight: bold">(</span><span style="color: #000000">HEATING_PERIOD</span><span style="color: #ce5c00; font-weight: bold">/</span><span style="color: #0000cf; font-weight: bold">60</span><span style="color: #000000; font-weight: bold">))</span> | ||
+ | <span style="color: #000000">time</span><span style="color: #ce5c00; font-weight: bold">.</span><span style="color: #000000">sleep</span><span style="color: #000000; font-weight: bold">(</span><span style="color: #000000">HEATING_PERIOD</span><span style="color: #000000; font-weight: bold">)</span> | ||
+ | |||
+ | |||
+ | <span style="color: #000000">start_pump</span><span style="color: #000000; font-weight: bold">(</span><span style="color: #000000">pwms</span><span style="color: #000000; font-weight: bold">,</span> <span style="color: #0000cf; font-weight: bold">5</span><span style="color: #000000; font-weight: bold">)</span> | ||
+ | |||
+ | <span style="color: #000000">logger</span><span style="color: #ce5c00; font-weight: bold">.</span><span style="color: #000000">info</span><span style="color: #000000; font-weight: bold">(</span><span style="color: #4e9a06">"... start analyzing"</span><span style="color: #000000; font-weight: bold">)</span> | ||
+ | <span style="color: #000000">measurement</span> <span style="color: #ce5c00; font-weight: bold">=</span> <span style="color: #000000">take_measure</span><span style="color: #000000; font-weight: bold">()</span> | ||
+ | |||
+ | <span style="color: #204a87; font-weight: bold">if</span> <span style="color: #000000; font-weight: bold">(</span><span style="color: #000000">diff_results</span><span style="color: #000000; font-weight: bold">(</span><span style="color: #000000">baseline</span><span style="color: #000000; font-weight: bold">,</span> <span style="color: #000000">measurement</span><span style="color: #000000; font-weight: bold">)</span> <span style="color: #204a87; font-weight: bold">is</span> <span style="color: #204a87; font-weight: bold">True</span><span style="color: #000000; font-weight: bold">):</span> | ||
+ | <span style="color: #000000">logger</span><span style="color: #ce5c00; font-weight: bold">.</span><span style="color: #000000">info</span><span style="color: #000000; font-weight: bold">(</span><span style="color: #4e9a06">" TURN !!"</span><span style="color: #000000; font-weight: bold">)</span> | ||
+ | <span style="color: #000000">reply</span> <span style="color: #ce5c00; font-weight: bold">=</span> <span style="color: #4e9a06">'turn'</span> | ||
+ | <span style="color: #204a87; font-weight: bold">else</span><span style="color: #000000; font-weight: bold">:</span> | ||
+ | <span style="color: #000000">reply</span> <span style="color: #ce5c00; font-weight: bold">=</span> <span style="color: #4e9a06">'drive'</span> | ||
+ | |||
+ | <span style="color: #204a87; font-weight: bold">elif</span> <span style="color: #000000">data</span><span style="color: #ce5c00; font-weight: bold">.</span><span style="color: #000000">decode</span><span style="color: #000000; font-weight: bold">(</span><span style="color: #4e9a06">"utf-8"</span><span style="color: #000000; font-weight: bold">)</span> <span style="color: #ce5c00; font-weight: bold">==</span> <span style="color: #000000">HEATING_TEST</span><span style="color: #000000; font-weight: bold">:</span> <span style="color: #8f5902; font-style: italic"># 'heat'</span> | ||
+ | <span style="color: #000000">logger</span><span style="color: #ce5c00; font-weight: bold">.</span><span style="color: #000000">info</span><span style="color: #000000; font-weight: bold">(</span><span style="color: #4e9a06">"received HEATING_TEST"</span><span style="color: #000000; font-weight: bold">)</span> | ||
+ | <span style="color: #000000">reply</span> <span style="color: #ce5c00; font-weight: bold">=</span> <span style="color: #4e9a06">'OK: HEATING TEST for 5 seconds ...'</span> | ||
+ | <span style="color: #000000">toggle_heating</span><span style="color: #000000; font-weight: bold">(</span><span style="color: #204a87; font-weight: bold">True</span><span style="color: #000000; font-weight: bold">)</span> | ||
+ | <span style="color: #000000">time</span><span style="color: #ce5c00; font-weight: bold">.</span><span style="color: #000000">sleep</span><span style="color: #000000; font-weight: bold">(</span><span style="color: #0000cf; font-weight: bold">5</span><span style="color: #000000; font-weight: bold">)</span> | ||
+ | <span style="color: #000000">toggle_heating</span><span style="color: #000000; font-weight: bold">(</span><span style="color: #204a87; font-weight: bold">False</span><span style="color: #000000; font-weight: bold">)</span> | ||
+ | |||
+ | <span style="color: #204a87; font-weight: bold">elif</span> <span style="color: #000000">data</span><span style="color: #ce5c00; font-weight: bold">.</span><span style="color: #000000">decode</span><span style="color: #000000; font-weight: bold">(</span><span style="color: #4e9a06">"utf-8"</span><span style="color: #000000; font-weight: bold">)</span> <span style="color: #ce5c00; font-weight: bold">==</span> <span style="color: #000000">PUMP_1_TEST</span><span style="color: #000000; font-weight: bold">:</span> <span style="color: #8f5902; font-style: italic"># 'pump_1'</span> | ||
+ | <span style="color: #000000">logger</span><span style="color: #ce5c00; font-weight: bold">.</span><span style="color: #000000">info</span><span style="color: #000000; font-weight: bold">(</span><span style="color: #4e9a06">"received PUMP_1_TEST"</span><span style="color: #000000; font-weight: bold">)</span> | ||
+ | <span style="color: #000000">reply</span> <span style="color: #ce5c00; font-weight: bold">=</span> <span style="color: #4e9a06">'OK: PUMPING TEST for 11 seconds (measure cycle)'</span> | ||
+ | <span style="color: #000000">start_pump</span><span style="color: #000000; font-weight: bold">(</span><span style="color: #000000">pwms</span><span style="color: #000000; font-weight: bold">,</span> <span style="color: #0000cf; font-weight: bold">11</span><span style="color: #000000; font-weight: bold">)</span> | ||
+ | |||
+ | <span style="color: #204a87; font-weight: bold">elif</span> <span style="color: #000000">data</span><span style="color: #ce5c00; font-weight: bold">.</span><span style="color: #000000">decode</span><span style="color: #000000; font-weight: bold">(</span><span style="color: #4e9a06">"utf-8"</span><span style="color: #000000; font-weight: bold">)</span> <span style="color: #ce5c00; font-weight: bold">==</span> <span style="color: #000000">GET_TEMP</span><span style="color: #000000; font-weight: bold">:</span> <span style="color: #8f5902; font-style: italic"># 'temp'</span> | ||
+ | <span style="color: #000000">logger</span><span style="color: #ce5c00; font-weight: bold">.</span><span style="color: #000000">info</span><span style="color: #000000; font-weight: bold">(</span><span style="color: #4e9a06">"received GET_TEMP"</span><span style="color: #000000; font-weight: bold">)</span> | ||
+ | <span style="color: #000000">temp</span> <span style="color: #ce5c00; font-weight: bold">=</span> <span style="color: #000000">get_temperature</span><span style="color: #000000; font-weight: bold">()</span> | ||
+ | <span style="color: #000000">reply</span> <span style="color: #ce5c00; font-weight: bold">=</span> <span style="color: #4e9a06">'OK: temperature is '</span> <span style="color: #ce5c00; font-weight: bold">+</span> \ | ||
+ | <span style="color: #204a87">str</span><span style="color: #000000; font-weight: bold">(</span><span style="color: #000000">temp</span><span style="color: #000000; font-weight: bold">)</span> <span style="color: #ce5c00; font-weight: bold">+</span> <span style="color: #4e9a06">' degree Celsius ...'</span> | ||
+ | |||
+ | <span style="color: #204a87; font-weight: bold">elif</span> <span style="color: #000000">data</span><span style="color: #ce5c00; font-weight: bold">.</span><span style="color: #000000">decode</span><span style="color: #000000; font-weight: bold">(</span><span style="color: #4e9a06">"utf-8"</span><span style="color: #000000; font-weight: bold">)</span> <span style="color: #ce5c00; font-weight: bold">==</span> <span style="color: #000000">CAM_TEST</span><span style="color: #000000; font-weight: bold">:</span> <span style="color: #8f5902; font-style: italic"># 'cam'</span> | ||
+ | <span style="color: #000000">logger</span><span style="color: #ce5c00; font-weight: bold">.</span><span style="color: #000000">info</span><span style="color: #000000; font-weight: bold">(</span><span style="color: #4e9a06">"received CAM_TEST"</span><span style="color: #000000; font-weight: bold">)</span> | ||
+ | <span style="color: #000000">result</span> <span style="color: #ce5c00; font-weight: bold">=</span> <span style="color: #000000">cam</span><span style="color: #ce5c00; font-weight: bold">.</span><span style="color: #000000">measure</span><span style="color: #000000; font-weight: bold">()</span> | ||
+ | <span style="color: #000000">reply</span> <span style="color: #ce5c00; font-weight: bold">=</span> <span style="color: #4e9a06">'OK: Took pic, result = '</span> <span style="color: #ce5c00; font-weight: bold">+</span> <span style="color: #204a87">str</span><span style="color: #000000; font-weight: bold">(</span><span style="color: #000000">result</span><span style="color: #000000; font-weight: bold">)</span> | ||
+ | <span style="color: #000000">cam</span><span style="color: #ce5c00; font-weight: bold">.</span><span style="color: #000000">exit_clean</span><span style="color: #000000; font-weight: bold">()</span> | ||
+ | <span style="color: #204a87; font-weight: bold">elif</span> <span style="color: #000000">data</span><span style="color: #ce5c00; font-weight: bold">.</span><span style="color: #000000">decode</span><span style="color: #000000; font-weight: bold">(</span><span style="color: #4e9a06">"utf-8"</span><span style="color: #000000; font-weight: bold">)</span> <span style="color: #ce5c00; font-weight: bold">==</span> <span style="color: #000000">DRIVE</span><span style="color: #000000; font-weight: bold">:</span> <span style="color: #8f5902; font-style: italic"># 'drive'</span> | ||
+ | <span style="color: #000000">logger</span><span style="color: #ce5c00; font-weight: bold">.</span><span style="color: #000000">info</span><span style="color: #000000; font-weight: bold">(</span><span style="color: #4e9a06">"received DRIVE"</span><span style="color: #000000; font-weight: bold">)</span> | ||
+ | <span style="color: #000000">reply</span> <span style="color: #ce5c00; font-weight: bold">=</span> <span style="color: #4e9a06">'drive'</span> | ||
+ | <span style="color: #204a87; font-weight: bold">elif</span> <span style="color: #000000">data</span><span style="color: #ce5c00; font-weight: bold">.</span><span style="color: #000000">decode</span><span style="color: #000000; font-weight: bold">(</span><span style="color: #4e9a06">"utf-8"</span><span style="color: #000000; font-weight: bold">)</span> <span style="color: #ce5c00; font-weight: bold">==</span> <span style="color: #000000">TURN</span><span style="color: #000000; font-weight: bold">:</span> <span style="color: #8f5902; font-style: italic"># 'turn'</span> | ||
+ | <span style="color: #000000">logger</span><span style="color: #ce5c00; font-weight: bold">.</span><span style="color: #000000">info</span><span style="color: #000000; font-weight: bold">(</span><span style="color: #4e9a06">"received TURN"</span><span style="color: #000000; font-weight: bold">)</span> | ||
+ | <span style="color: #000000">reply</span> <span style="color: #ce5c00; font-weight: bold">=</span> <span style="color: #4e9a06">'turn'</span> | ||
+ | |||
+ | |||
+ | <span style="color: #204a87; font-weight: bold">else</span><span style="color: #000000; font-weight: bold">:</span> | ||
+ | <span style="color: #000000">logger</span><span style="color: #ce5c00; font-weight: bold">.</span><span style="color: #000000">info</span><span style="color: #000000; font-weight: bold">(</span><span style="color: #4e9a06">"invalid message"</span><span style="color: #000000; font-weight: bold">)</span> | ||
+ | <span style="color: #000000">reply</span> <span style="color: #ce5c00; font-weight: bold">=</span> <span style="color: #4e9a06">'FAIL: ... invalid message: ['</span> <span style="color: #ce5c00; font-weight: bold">+</span> \ | ||
+ | <span style="color: #000000">data</span><span style="color: #ce5c00; font-weight: bold">.</span><span style="color: #000000">decode</span><span style="color: #000000; font-weight: bold">(</span><span style="color: #4e9a06">"utf-8"</span><span style="color: #000000; font-weight: bold">)</span> <span style="color: #ce5c00; font-weight: bold">+</span> <span style="color: #4e9a06">']'</span> | ||
+ | |||
+ | |||
+ | <span style="color: #000000">sock</span><span style="color: #ce5c00; font-weight: bold">.</span><span style="color: #000000">sendto</span><span style="color: #000000; font-weight: bold">(</span><span style="color: #000000">reply</span><span style="color: #ce5c00; font-weight: bold">.</span><span style="color: #000000">encode</span><span style="color: #000000; font-weight: bold">(</span><span style="color: #4e9a06">"UTF-8"</span><span style="color: #000000; font-weight: bold">),</span> <span style="color: #000000">addr</span><span style="color: #000000; font-weight: bold">)</span> | ||
+ | <span style="color: #000000">logger</span><span style="color: #ce5c00; font-weight: bold">.</span><span style="color: #000000">info</span><span style="color: #000000; font-weight: bold">(</span><span style="color: #4e9a06">"Sent message."</span><span style="color: #000000; font-weight: bold">)</span> | ||
+ | |||
+ | <span style="color: #8f5902; font-style: italic"># logger.info('Message[' + addr[0] + ':' +</span> | ||
+ | <span style="color: #8f5902; font-style: italic"># str(addr[1]) + '] - ' + data.decode("utf-8"))</span> | ||
+ | |||
+ | <span style="color: #204a87; font-weight: bold">except</span> <span style="color: #cc0000; font-weight: bold">KeyboardInterrupt</span><span style="color: #000000; font-weight: bold">:</span> | ||
+ | <span style="color: #000000">logger</span><span style="color: #ce5c00; font-weight: bold">.</span><span style="color: #000000">info</span><span style="color: #000000; font-weight: bold">(</span><span style="color: #4e9a06">"Quitting."</span><span style="color: #000000; font-weight: bold">)</span> | ||
+ | <span style="color: #204a87; font-weight: bold">if</span> <span style="color: #000000">HEATING</span><span style="color: #000000; font-weight: bold">:</span> | ||
+ | <span style="color: #000000">toggle_heating</span><span style="color: #000000; font-weight: bold">(</span><span style="color: #204a87; font-weight: bold">False</span><span style="color: #000000; font-weight: bold">)</span> | ||
+ | |||
+ | <span style="color: #000000">sock</span><span style="color: #ce5c00; font-weight: bold">.</span><span style="color: #000000">close</span><span style="color: #000000; font-weight: bold">()</span> | ||
+ | <span style="color: #000000">GPIO</span><span style="color: #ce5c00; font-weight: bold">.</span><span style="color: #000000">cleanup</span><span style="color: #000000; font-weight: bold">()</span> | ||
+ | <span style="color: #000000">cam</span><span style="color: #ce5c00; font-weight: bold">.</span><span style="color: #000000">exit_clean</span><span style="color: #000000; font-weight: bold">()</span> | ||
+ | |||
+ | <span style="color: #204a87; font-weight: bold">def</span> <span style="color: #000000">main</span><span style="color: #000000; font-weight: bold">():</span> | ||
+ | |||
+ | <span style="color: #8f5902; font-style: italic"># format</span> | ||
+ | <span style="color: #000000">FORMAT</span> <span style="color: #ce5c00; font-weight: bold">=</span> <span style="color: #4e9a06">"[%(asctime)s %(funcName)18s()] %(message)s"</span> | ||
+ | <span style="color: #000000">fileHandler</span> <span style="color: #ce5c00; font-weight: bold">=</span> <span style="color: #000000">logging</span><span style="color: #ce5c00; font-weight: bold">.</span><span style="color: #000000">FileHandler</span><span style="color: #000000; font-weight: bold">(</span><span style="color: #4e9a06">'log.txt'</span><span style="color: #000000; font-weight: bold">)</span> | ||
+ | <span style="color: #000000">fileHandler</span><span style="color: #ce5c00; font-weight: bold">.</span><span style="color: #000000">setFormatter</span><span style="color: #000000; font-weight: bold">(</span><span style="color: #000000">logging</span><span style="color: #ce5c00; font-weight: bold">.</span><span style="color: #000000">Formatter</span><span style="color: #000000; font-weight: bold">(</span><span style="color: #000000">FORMAT</span><span style="color: #000000; font-weight: bold">))</span> | ||
+ | <span style="color: #000000">logger</span><span style="color: #ce5c00; font-weight: bold">.</span><span style="color: #000000">addHandler</span><span style="color: #000000; font-weight: bold">(</span><span style="color: #000000">fileHandler</span><span style="color: #000000; font-weight: bold">)</span> | ||
+ | <span style="color: #000000">logging</span><span style="color: #ce5c00; font-weight: bold">.</span><span style="color: #000000">basicConfig</span><span style="color: #000000; font-weight: bold">(</span><span style="color: #000000">level</span><span style="color: #ce5c00; font-weight: bold">=</span><span style="color: #0000cf; font-weight: bold">20</span><span style="color: #000000; font-weight: bold">,</span> <span style="color: #204a87">format</span><span style="color: #ce5c00; font-weight: bold">=</span><span style="color: #000000">FORMAT</span><span style="color: #000000; font-weight: bold">,</span> <span style="color: #000000">datefmt</span><span style="color: #ce5c00; font-weight: bold">=</span><span style="color: #4e9a06">'%d.%m.%Y %H:%M:%S'</span><span style="color: #000000; font-weight: bold">)</span> | ||
+ | |||
+ | <span style="color: #000000">logger</span><span style="color: #ce5c00; font-weight: bold">.</span><span style="color: #000000">info</span><span style="color: #000000; font-weight: bold">(</span><span style="color: #4e9a06">"Start logging"</span><span style="color: #000000; font-weight: bold">)</span> | ||
+ | |||
+ | <span style="color: #8f5902; font-style: italic"># setup GPIO</span> | ||
+ | <span style="color: #000000">GPIO</span><span style="color: #ce5c00; font-weight: bold">.</span><span style="color: #000000">setmode</span><span style="color: #000000; font-weight: bold">(</span><span style="color: #000000">GPIO</span><span style="color: #ce5c00; font-weight: bold">.</span><span style="color: #000000">BOARD</span><span style="color: #000000; font-weight: bold">)</span> | ||
+ | <span style="color: #000000">GPIO</span><span style="color: #ce5c00; font-weight: bold">.</span><span style="color: #000000">setup</span><span style="color: #000000; font-weight: bold">(</span><span style="color: #000000">HEAT</span><span style="color: #000000; font-weight: bold">,</span> <span style="color: #000000">GPIO</span><span style="color: #ce5c00; font-weight: bold">.</span><span style="color: #000000">OUT</span><span style="color: #000000; font-weight: bold">)</span> | ||
+ | <span style="color: #000000">GPIO</span><span style="color: #ce5c00; font-weight: bold">.</span><span style="color: #000000">output</span><span style="color: #000000; font-weight: bold">(</span><span style="color: #000000">HEAT</span><span style="color: #000000; font-weight: bold">,</span> <span style="color: #0000cf; font-weight: bold">0</span><span style="color: #000000; font-weight: bold">)</span> | ||
+ | |||
+ | <span style="color: #8f5902; font-style: italic">#pwm1</span> | ||
+ | <span style="color: #000000">GPIO</span><span style="color: #ce5c00; font-weight: bold">.</span><span style="color: #000000">setup</span><span style="color: #000000; font-weight: bold">(</span><span style="color: #0000cf; font-weight: bold">11</span><span style="color: #000000; font-weight: bold">,</span> <span style="color: #000000">GPIO</span><span style="color: #ce5c00; font-weight: bold">.</span><span style="color: #000000">OUT</span><span style="color: #000000; font-weight: bold">)</span> | ||
+ | |||
+ | <span style="color: #000000">GPIO</span><span style="color: #ce5c00; font-weight: bold">.</span><span style="color: #000000">setup</span><span style="color: #000000; font-weight: bold">(</span><span style="color: #0000cf; font-weight: bold">13</span><span style="color: #000000; font-weight: bold">,</span> <span style="color: #000000">GPIO</span><span style="color: #ce5c00; font-weight: bold">.</span><span style="color: #000000">OUT</span><span style="color: #000000; font-weight: bold">)</span> | ||
+ | |||
+ | <span style="color: #000000">GPIO</span><span style="color: #ce5c00; font-weight: bold">.</span><span style="color: #000000">setup</span><span style="color: #000000; font-weight: bold">(</span><span style="color: #0000cf; font-weight: bold">15</span><span style="color: #000000; font-weight: bold">,</span> <span style="color: #000000">GPIO</span><span style="color: #ce5c00; font-weight: bold">.</span><span style="color: #000000">OUT</span><span style="color: #000000; font-weight: bold">)</span> | ||
+ | |||
+ | |||
+ | <span style="color: #000000">pwm1</span> <span style="color: #ce5c00; font-weight: bold">=</span> <span style="color: #000000">GPIO</span><span style="color: #ce5c00; font-weight: bold">.</span><span style="color: #000000">PWM</span><span style="color: #000000; font-weight: bold">(</span><span style="color: #0000cf; font-weight: bold">11</span><span style="color: #000000; font-weight: bold">,</span> <span style="color: #0000cf; font-weight: bold">220</span><span style="color: #000000; font-weight: bold">)</span> | ||
+ | <span style="color: #000000">GPIO</span><span style="color: #ce5c00; font-weight: bold">.</span><span style="color: #000000">output</span><span style="color: #000000; font-weight: bold">(</span><span style="color: #0000cf; font-weight: bold">13</span><span style="color: #000000; font-weight: bold">,</span> <span style="color: #0000cf; font-weight: bold">0</span><span style="color: #000000; font-weight: bold">)</span> | ||
+ | <span style="color: #000000">GPIO</span><span style="color: #ce5c00; font-weight: bold">.</span><span style="color: #000000">output</span><span style="color: #000000; font-weight: bold">(</span><span style="color: #0000cf; font-weight: bold">15</span><span style="color: #000000; font-weight: bold">,</span> <span style="color: #0000cf; font-weight: bold">1</span><span style="color: #000000; font-weight: bold">)</span> | ||
+ | |||
+ | <span style="color: #8f5902; font-style: italic">#pwm2</span> | ||
+ | <span style="color: #000000">GPIO</span><span style="color: #ce5c00; font-weight: bold">.</span><span style="color: #000000">setup</span><span style="color: #000000; font-weight: bold">(</span><span style="color: #0000cf; font-weight: bold">29</span><span style="color: #000000; font-weight: bold">,</span> <span style="color: #000000">GPIO</span><span style="color: #ce5c00; font-weight: bold">.</span><span style="color: #000000">OUT</span><span style="color: #000000; font-weight: bold">)</span> | ||
+ | |||
+ | <span style="color: #000000">GPIO</span><span style="color: #ce5c00; font-weight: bold">.</span><span style="color: #000000">setup</span><span style="color: #000000; font-weight: bold">(</span><span style="color: #0000cf; font-weight: bold">31</span><span style="color: #000000; font-weight: bold">,</span> <span style="color: #000000">GPIO</span><span style="color: #ce5c00; font-weight: bold">.</span><span style="color: #000000">OUT</span><span style="color: #000000; font-weight: bold">)</span> | ||
+ | |||
+ | <span style="color: #000000">GPIO</span><span style="color: #ce5c00; font-weight: bold">.</span><span style="color: #000000">setup</span><span style="color: #000000; font-weight: bold">(</span><span style="color: #0000cf; font-weight: bold">33</span><span style="color: #000000; font-weight: bold">,</span> <span style="color: #000000">GPIO</span><span style="color: #ce5c00; font-weight: bold">.</span><span style="color: #000000">OUT</span><span style="color: #000000; font-weight: bold">)</span> | ||
+ | |||
+ | <span style="color: #000000">pwm2</span> <span style="color: #ce5c00; font-weight: bold">=</span> <span style="color: #000000">GPIO</span><span style="color: #ce5c00; font-weight: bold">.</span><span style="color: #000000">PWM</span><span style="color: #000000; font-weight: bold">(</span><span style="color: #0000cf; font-weight: bold">29</span><span style="color: #000000; font-weight: bold">,</span> <span style="color: #0000cf; font-weight: bold">220</span><span style="color: #000000; font-weight: bold">)</span> | ||
+ | <span style="color: #000000">GPIO</span><span style="color: #ce5c00; font-weight: bold">.</span><span style="color: #000000">output</span><span style="color: #000000; font-weight: bold">(</span><span style="color: #0000cf; font-weight: bold">31</span><span style="color: #000000; font-weight: bold">,</span> <span style="color: #0000cf; font-weight: bold">0</span><span style="color: #000000; font-weight: bold">)</span> | ||
+ | <span style="color: #000000">GPIO</span><span style="color: #ce5c00; font-weight: bold">.</span><span style="color: #000000">output</span><span style="color: #000000; font-weight: bold">(</span><span style="color: #0000cf; font-weight: bold">33</span><span style="color: #000000; font-weight: bold">,</span> <span style="color: #0000cf; font-weight: bold">1</span><span style="color: #000000; font-weight: bold">)</span> | ||
+ | |||
+ | <span style="color: #000000">pwms</span> <span style="color: #ce5c00; font-weight: bold">=</span> <span style="color: #000000; font-weight: bold">[</span><span style="color: #000000">pwm1</span><span style="color: #000000; font-weight: bold">,</span> <span style="color: #000000">pwm2</span><span style="color: #000000; font-weight: bold">]</span> | ||
+ | |||
+ | <span style="color: #000000">logger</span><span style="color: #ce5c00; font-weight: bold">.</span><span style="color: #000000">info</span><span style="color: #000000; font-weight: bold">(</span><span style="color: #4e9a06">"###############################"</span><span style="color: #000000; font-weight: bold">)</span> | ||
+ | <span style="color: #000000">logger</span><span style="color: #ce5c00; font-weight: bold">.</span><span style="color: #000000">info</span><span style="color: #000000; font-weight: bold">(</span><span style="color: #4e9a06">" ColiBot Thermo udp_server "</span><span style="color: #000000; font-weight: bold">)</span> | ||
+ | <span style="color: #000000">logger</span><span style="color: #ce5c00; font-weight: bold">.</span><span style="color: #000000">info</span><span style="color: #000000; font-weight: bold">(</span><span style="color: #4e9a06">"-------------------------------"</span><span style="color: #000000; font-weight: bold">)</span> | ||
+ | <span style="color: #000000">sock</span> <span style="color: #ce5c00; font-weight: bold">=</span> <span style="color: #000000">create_socket</span><span style="color: #000000; font-weight: bold">()</span> | ||
+ | <span style="color: #000000">logger</span><span style="color: #ce5c00; font-weight: bold">.</span><span style="color: #000000">info</span><span style="color: #000000; font-weight: bold">(</span><span style="color: #4e9a06">"-------------------------------"</span><span style="color: #000000; font-weight: bold">)</span> | ||
+ | <span style="color: #000000">logger</span><span style="color: #ce5c00; font-weight: bold">.</span><span style="color: #000000">info</span><span style="color: #000000; font-weight: bold">(</span><span style="color: #4e9a06">"... start listening ..."</span><span style="color: #000000; font-weight: bold">)</span> | ||
+ | <span style="color: #000000">start_listening</span><span style="color: #000000; font-weight: bold">(</span><span style="color: #000000">sock</span><span style="color: #000000; font-weight: bold">,</span> <span style="color: #000000">pwms</span><span style="color: #000000; font-weight: bold">)</span> | ||
+ | |||
+ | <span style="color: #000000">cam</span> <span style="color: #ce5c00; font-weight: bold">=</span> <span style="color: #000000">ColiCamMaster</span><span style="color: #000000; font-weight: bold">()</span> | ||
+ | <span style="color: #000000">ColiCamSlave</span><span style="color: #000000; font-weight: bold">()</span> | ||
+ | |||
+ | |||
+ | <span style="color: #204a87; font-weight: bold">if</span> <span style="color: #000000">__name__</span> <span style="color: #ce5c00; font-weight: bold">==</span> <span style="color: #4e9a06">"__main__"</span><span style="color: #000000; font-weight: bold">:</span> | ||
+ | <span style="color: #000000">main</span><span style="color: #000000; font-weight: bold">()</span> | ||
+ | </pre></td></tr></table></div> | ||
+ | |||
+ | </div> | ||
+ | |||
+ | </div> | ||
+ | </div> | ||
+ | <br> | ||
+ | </html> | ||
{{NAWI_Graz:footer}} | {{NAWI_Graz:footer}} |
Latest revision as of 03:56, 2 November 2017
CONTROL SYSTEM
The
Server
Our server was built and programmed as the centerpiece of the control architecture that encompasses the bioreactor and measurement
system of
The server code controls the interaction modules, the measurement chambers and the communication with the robot in the arena. It listens for commands that are sent by either the robot or the client software and reacts by executing the following functions.
Directly available
-Server functions activated by commands sent from client:
-
heat
Starts the heating module for 5 seconds. -
pump_1
Start all pumps for 11 seconds (the length of one measure cycle) to flush the system and fill it with fresh suspension from the reactor. -
temp
Get the current temperature reading from the themperature sensor in the Temperature Interaction Module. -
cam
Take a testpicture with the master camera and report the measurement result. -
drive
Send out adrive
command to the Robot to test range and connection. -
turn
Send out aturn
command to the Robot to calibrate the radius.
In the case of a real experiment run in the temperature setup, the robot sends one of the following messages to the server according to its position and orientation in the arena and the sensor input it perceives. The server reacts by initiating the corresponding processes as described below.
Robot - Server Interaction :
-
clear
The server starts a waiting loop to cool down the potentially still hot heating chamber to prevent tainting the current run by previous runs. After this cool-down period, fresh suspension is pumped into the measurement chamber and a baseline measurement is conducted. To prevent any unknown or outside influences, another waiting loop, identical in duration to the activation heating period during a run with activated temperature interaction, is started now. Finally, the suspension is pumped into the measurement chamber and a measurement is taken. The baseline measurement and actual measurement data is now compared and in case the difference surpasses a given threshold, the server sends the
turn
command to the robot. Otherwisedrive
sent to the robot to signal an open path ahead. -
obstacle
The server starts with a cool-down period to prevent tainted measuring results. A baseline measurement is made with fresh suspension. Fresh suspension is pumped into the temperature interaction module and heated to target temperature. The heated and activated suspension is pumped into the measurement chamber and a measurement is taken and compared to the baseline value. If the baseline and the actual measurement have a difference equal or greater than the given threshold, the server sends the
turn
command to the robot. Otherwisedrive
sent to the robot to signal an open path ahead.
The
Client
To be able to test all of the control systems functionality (pump control, heating, measurements) without having
to actually run the full experiments, a small command line application was written in Python3. Intended to being
run on any computer in the same network as the
The commands are sent and answers are received over UDP, a common data transfer protocol. Although not reliable for critical communication because of missing error checking and guaranteed order of the packets arriving, for the small data packets we are sending here it is sufficient.
The client code for testing the system functionality:
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 | #!/usr/sbin/python3 # ColiBot Client # - # A minimal udp messaging client to send (test) messages to the ColiBot server. # import socket import sys # create datagram udp socket try: sock = socket.socket(socket.AF_INET, socket.SOCK_DGRAM) except socket.error: print('Failed to create socket') sys.exit() host = '192.168.0.4' port = 4343 while(1): msg = input('Enter message to send : ') try: # Send string sock.sendto(str.encode(msg), (host, port)) # receive data from client (data, addr) d = sock.recvfrom(1024) reply = d[0] addr = d[1] print('Server reply : ' + str(reply)) if (reply.decode("utf-8") == 'turn'): print("Got 'turn' message.") if (reply.decode("utf-8") == 'drive'): print("Got 'drive' message.") except socket.error as e: print('Socket Error: {}'.format(e)) sock.close() sys.exit() except KeyboardInterrupt: sock.close() sys.exit() |
The server code for controlling the bioreactor and measurement system:
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 137 138 139 140 141 142 143 144 145 146 147 148 149 150 151 152 153 154 155 156 157 158 159 160 161 162 163 164 165 166 167 168 169 170 171 172 173 174 175 176 177 178 179 180 181 182 183 184 185 186 187 188 189 190 191 192 193 194 195 196 197 198 199 200 201 202 203 204 205 206 207 208 209 210 211 212 213 214 215 216 217 218 219 220 221 222 223 224 225 226 227 228 229 230 231 232 233 234 235 236 237 238 239 240 241 242 243 244 245 246 247 248 249 250 251 252 253 254 255 256 257 258 259 260 261 262 263 264 265 266 267 268 269 270 271 272 273 274 275 276 277 278 279 280 281 282 283 284 285 286 287 288 289 290 291 292 293 294 295 296 297 298 299 300 301 302 303 304 305 306 307 308 309 310 311 312 313 314 315 316 317 318 319 320 321 322 323 324 325 326 327 328 329 330 331 332 333 334 335 336 337 338 339 340 341 342 343 344 345 346 347 348 349 350 351 352 353 354 355 356 357 358 359 360 361 362 363 364 | #! /usr/bin/python3 # Simple udp socket server import calendar import datetime import logging import socket import sys import time import RPi.GPIO as GPIO import serial from cam.colicam_master import ColiCamMaster from cam.colicam_slave import ColiCamSlave from w1thermsensor import W1ThermSensor # heater pins HEAT = 40 PORT = 4343 # Arbitrary non-privileged port HOST = "192.168.43.150" # Messages OBSTACLE = 'obstacle' CLEAR = 'clear' HEATING_TEST = 'heat' GET_TEMP = 'temp' PUMP_1_TEST = 'pump_1' CAM_TEST = 'cam' TURN = 'turn' DRIVE = 'drive' # heating HEATING = False TARGET_TEMP = 43 # degrees INTERVALL = 8 # seconds HEATING_PERIOD = 300 # seconds # pump PUMP_IVALL = 12 DIFF_THRESHOLD = 12 logger = logging.getLogger('colibot') def get_temperature(): """ read temperature from sensor """ sensor = W1ThermSensor() temp_c = sensor.get_temperature() return temp_c def toggle_heating(heat): """ GPIO 20 and 21 HIGH = heating on LOW = heating off """ if heat is False: #logger.info("HEATING OFF") HEATING = False GPIO.output(HEAT, 0) else: #logger.info("HEATING ON") HEATING = True GPIO.output(HEAT, 1) def start_heating(): """ """ logger.info("*** Entering heating loop ...") while(1): temp = get_temperature() logger.info("*** Current temperature: " + str(temp)) if temp >= (TARGET_TEMP - 2): logger.info("*** TARGET_TEMP reached!") break; toggle_heating(True) time.sleep(15) toggle_heating(False) heating_time = HEATING_PERIOD # seconds start = calendar.timegm(time.gmtime()) end = start + heating_time logger.info("*** activation period, keeping target temp for 5 mins:") remaining_time = heating_time while(1): # logger.info("minutes left: "+str( (end - calendar.timegm(time.gmtime()))/60 ) ) if calendar.timegm(time.gmtime()) >= end: break temp = get_temperature() # logger.info("-->") logger.info("*** Current temperature: " + str(temp)) if temp >= (TARGET_TEMP ): time.sleep(10) elif( temp < TARGET_TEMP ): # logger.info("*** heating ...") toggle_heating(True) time.sleep(5) toggle_heating(False) #if remaining_time % 60 == 0: logger.info("> {} mins remaining.".format( remaining_time / 60 )) time.sleep(5) remaining_time -= 14 def start_pump(pwms, seconds): """ pump_1: pwms[0](11, 180) pin 13 pin 15 pump_2: pwms[1](19, 180) pin 21 pin 23 --> ~1ml per second """ logger.info("*** Starting pumps for {} seconds.".format(str(seconds))) pwms[0].start(100) # out pwms[1].start(100) # in time.sleep(seconds) logger.info("*** Stopping pumps") pwms[0].stop() pwms[1].stop() def take_measure(): logger.info("*** Measuring ...") result = cam.measure() return result; def diff_results(bl, m): r_diff = abs(bl[0] - m[0]) g_diff = abs(bl[1] - m[1]) b_diff = abs(bl[2] - m[2]) diff = r_diff + g_diff + b_diff logger.info("*** Diff_results: r_diff={} g_diff={} b_diff={}".format(r_diff, g_diff, b_diff)) logger.info("*** total: {}".format(diff)) if(diff >= DIFF_THRESHOLD): return True else: return False def create_socket(): # Datagram (udp) socket try: sock = socket.socket(socket.AF_INET, socket.SOCK_DGRAM) logger.info('Socket created') except socket.error as msg: logger.error('Failed to create socket.') GPIO.cleanup() sys.exit() # Bind socket to local host and port try: sock.bind((HOST, PORT)) except socket.error as msg: logger.error('Bind failed. ') GPIO.cleanup() sys.exit() logger.info('Socket bind complete') return sock def start_listening(sock, pwms): # now keep talking with the client try: while 1: # receive data from client (data, addr) rec = sock.recvfrom(1024) data = rec[0] addr = rec[1] logger.info("***") if data.decode("utf-8") == OBSTACLE: # 'obstacle' logger.info( "recieved OBSTACLE: requesting colis and heating them to TARGET_TEMP...") # wait for some time to cool of heating chamber cooldown = 180 logger.info("Waiting {} to cool chamber.".format(cooldown/60)) time.sleep(cooldown) # fill chamber for baseline measureing start_pump(pwms, PUMP_IVALL) # baseline baseline = take_measure() logger.info("baseline values: r{}, g{}, b{}".format(baseline[0], baseline[1], baseline[2])) start_heating() # activated to chamber start_pump(pwms, 5) logger.info("... start analyzing") measurement = take_measure() if (diff_results(baseline, measurement) is True): logger.info(" TURN !!.") reply = 'turn' else: logger.info(" DRIVE !!.") reply = 'drive' elif data.decode("utf-8") == CLEAR: # 'clear' logger.info("recieved CLEAR: requesting colis and start analyzing.") # wait for some time to cool of heating chamber cooldown = 180 logger.info("Waiting {} to cool chamber.".format(cooldown/60)) time.sleep(cooldown) # fill chamber for baseline measureing start_pump(pwms, PUMP_IVALL) # baseline baseline = take_measure() logger.info("baseline values: r{}, g{}, b{}".format(baseline[0], baseline[1], baseline[2])) logger.info("waiting loop: {} minutes.".format(HEATING_PERIOD/60)) time.sleep(HEATING_PERIOD) start_pump(pwms, 5) logger.info("... start analyzing") measurement = take_measure() if (diff_results(baseline, measurement) is True): logger.info(" TURN !!") reply = 'turn' else: reply = 'drive' elif data.decode("utf-8") == HEATING_TEST: # 'heat' logger.info("received HEATING_TEST") reply = 'OK: HEATING TEST for 5 seconds ...' toggle_heating(True) time.sleep(5) toggle_heating(False) elif data.decode("utf-8") == PUMP_1_TEST: # 'pump_1' logger.info("received PUMP_1_TEST") reply = 'OK: PUMPING TEST for 11 seconds (measure cycle)' start_pump(pwms, 11) elif data.decode("utf-8") == GET_TEMP: # 'temp' logger.info("received GET_TEMP") temp = get_temperature() reply = 'OK: temperature is ' + \ str(temp) + ' degree Celsius ...' elif data.decode("utf-8") == CAM_TEST: # 'cam' logger.info("received CAM_TEST") result = cam.measure() reply = 'OK: Took pic, result = ' + str(result) cam.exit_clean() elif data.decode("utf-8") == DRIVE: # 'drive' logger.info("received DRIVE") reply = 'drive' elif data.decode("utf-8") == TURN: # 'turn' logger.info("received TURN") reply = 'turn' else: logger.info("invalid message") reply = 'FAIL: ... invalid message: [' + \ data.decode("utf-8") + ']' sock.sendto(reply.encode("UTF-8"), addr) logger.info("Sent message.") # logger.info('Message[' + addr[0] + ':' + # str(addr[1]) + '] - ' + data.decode("utf-8")) except KeyboardInterrupt: logger.info("Quitting.") if HEATING: toggle_heating(False) sock.close() GPIO.cleanup() cam.exit_clean() def main(): # format FORMAT = "[%(asctime)s %(funcName)18s()] %(message)s" fileHandler = logging.FileHandler('log.txt') fileHandler.setFormatter(logging.Formatter(FORMAT)) logger.addHandler(fileHandler) logging.basicConfig(level=20, format=FORMAT, datefmt='%d.%m.%Y %H:%M:%S') logger.info("Start logging") # setup GPIO GPIO.setmode(GPIO.BOARD) GPIO.setup(HEAT, GPIO.OUT) GPIO.output(HEAT, 0) #pwm1 GPIO.setup(11, GPIO.OUT) GPIO.setup(13, GPIO.OUT) GPIO.setup(15, GPIO.OUT) pwm1 = GPIO.PWM(11, 220) GPIO.output(13, 0) GPIO.output(15, 1) #pwm2 GPIO.setup(29, GPIO.OUT) GPIO.setup(31, GPIO.OUT) GPIO.setup(33, GPIO.OUT) pwm2 = GPIO.PWM(29, 220) GPIO.output(31, 0) GPIO.output(33, 1) pwms = [pwm1, pwm2] logger.info("###############################") logger.info(" ColiBot Thermo udp_server ") logger.info("-------------------------------") sock = create_socket() logger.info("-------------------------------") logger.info("... start listening ...") start_listening(sock, pwms) cam = ColiCamMaster() ColiCamSlave() if __name__ == "__main__": main() |