Modifications

Sauter à la navigation Sauter à la recherche
2 030 octets ajoutés ,  26 novembre 2022 à 14:43
Ligne 44 : Ligne 44 :  
|-
 
|-
 
| MOSI
 
| MOSI
| GP7 (Miso)
+
| GP7 (Mosi)
 
|-
 
|-
 
| MISO
 
| MISO
| GP4 (Mosi)
+
| GP4 (Miso)
 
|-
 
|-
 
| SCK
 
| SCK
Ligne 84 : Ligne 84 :  
Finally wire the RFM69HCW radio as follows
 
Finally wire the RFM69HCW radio as follows
   −
[[Fichier:ENG-CANSAT-PICO-RFM69HCW-to-Cansat-Pico-Base.jpg|640px]]
+
[[Fichier:ENG-CANSAT-PICO-RFM69HCW-to-Cansat-Pico-Base-fixed.jpg|640px]]
    
{| class="wikitable"  
 
{| class="wikitable"  
Ligne 103 : Ligne 103 :  
| keep the same pin as receiver.<br />Otherwise use UEXT 10 (=gp10)
 
| keep the same pin as receiver.<br />Otherwise use UEXT 10 (=gp10)
 
|-
 
|-
| MOSI
+
| MISO
 
| 7
 
| 7
 
|  
 
|  
 
| GP4 = MISO
 
| GP4 = MISO
 
|-
 
|-
| MISO
+
| MOSI
 
| 8
 
| 8
 
|  
 
|  
Ligne 132 : Ligne 132 :  
The code is available for download on the [https://github.com/mchobby/cansat-belgium-micropython GitHub associated to this wiki].
 
The code is available for download on the [https://github.com/mchobby/cansat-belgium-micropython GitHub associated to this wiki].
   −
{{download-box|Téléchargez Mission1 Cansat Emitter script (cansat.py)|https://raw.githubusercontent.com/mchobby/cansat-belgium/master/mission1/cansat.py}}
+
{{download-box|Téléchargez Mission1 Cansat Emitter script (cansat.py)|https://github.com/mchobby/cansat-belgium-micropython/blob/main/mission1/cansat.py}}
    
Without any comments, extra lines and print statement (used to debug), the script makes 33 lines long for the full fledged features.
 
Without any comments, extra lines and print statement (used to debug), the script makes 33 lines long for the full fledged features.
Ligne 201 : Ligne 201 :  
[[Fichier:ENG-CANSAT-PICO-MISSION1-CAPTURE-25.png|360px]]
 
[[Fichier:ENG-CANSAT-PICO-MISSION1-CAPTURE-25.png|360px]]
   −
The {{fname|cansat2.py}} script do re-enforce error controls with {{fname|try...except}} statements in the script and showing various onboard LED patterns in case of error.
+
The [https://github.com/mchobby/cansat-belgium-micropython/tree/main/mission1 cansat2.py] script do re-enforce error controls with {{fname|try...except}} statements in the script and showing various onboard LED patterns in case of error.
    
Error Code are reported as quick serie of blink following by slow blink... counting the slow blink gives the error code number.
 
Error Code are reported as quick serie of blink following by slow blink... counting the slow blink gives the error code number.
Ligne 330 : Ligne 330 :  
## Send message
 
## Send message
 
## Turn of the LED
 
## Turn of the LED
 +
 +
{{underline|'''Reading sensor data:'''}}
 +
 +
Reading the BMP280 sensor data relies on the {{fname|bme280.py} library previously detailled.
 +
 +
Reading the temperature from TMP36 relies on analog reading and some conversion calculation.
 +
 +
<syntaxhighlight lang="python"># read BMP280
 +
t,hpa,rh =  bmp.raw_values # Temp, press_hPa, humidity
 +
# Read tmp36 (analog)
 +
value = adc.read_u16()
 +
mv = 3300.0 * value / 65535
 +
temp = (mv-500)/10
 +
</syntaxhighlight>
 +
 +
Next the mainloop do prepare the string message (variable {{fname|msg}} by using the powerful Python string formatting feature.
 +
 +
{{underline|'''Formatting data:'''}}
 +
 +
This can be done with one single line. Notice the expression {{fname|time.time()-ctime}} calculating the elapse time (in second) since the mainloop started. 
 +
<syntaxhighlight lang="python"># message: iteration_count,time_sec,pressure_hpa,tmp36_temp,bmp280_temp (coma separated)
 +
msg = ":%i,%i,%6.2f,%5.2f,%5.2f;" % (counter,time.time()-ctime,hpa,temp,t)
 +
</syntaxhighlight>
 +
 +
{{underline|'''Sending data:'''}}
 +
 +
The onboard LED is switched on during data transmission (and print). This makes the LED flashing briefly while data us transmitted.
 +
 +
The data packet are sent without ACK, this would avoids unnecessary latency by waiting for ACK. Indeed, the Cansat will not modifies its behaviours if the data are not received on the ground station.
 +
 +
<syntaxhighlight lang="python">led.on() # Led ON while sending data
 +
print( msg )
 +
# Send a packet without ACK - Send it, don't care if it is received or not
 +
rfm.send(bytes(msg , "utf-8") )
 +
led.off()
 +
</syntaxhighlight>
 +
 +
Just to remind, the {{fname|rfm.send()}} only accepts binary data as generated with bytes() or bytearray(). The message string must be converted to a binary with {{fname|bytes()}}. As binary data does not accept value > 127 without a proper encoding then the bytes() conversion must identifies the encoding of the source string to applies the adequate encoding scheme (UTF8 -> Binary).
    
== Fault tolerant design ==
 
== Fault tolerant design ==
29 917

modifications

Menu de navigation