8c2393cd
rcavalie
travail reception...
|
1
2
3
4
5
6
7
8
9
10
11
12
|
////////////////////////////////////////////////////////////////////////////////
/*RECEPTEUR LoRa
par : Robin Cavalieri
IMA5SC
PFE 2018 */
////////////////////////////////////////////////////////////////////////////////
//Headers
#include "mbed.h"
#include "main.h"
#include "sx1276-hal.h"
#include "debug.h"
////////////////////////////////////////////////////////////////////////////////
|
757b04ad
rcavalie
création des data...
|
13
|
#define DEBUG_MESSAGE 0
|
8c2393cd
rcavalie
travail reception...
|
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
|
////////////////////////////////////////////////////////////////////////////////
////////////////////////////////////////////////////////////////////////////////
//Modulation LoRa active
#define USE_MODEM_LORA 1
#define USE_MODEM_FSK !USE_MODEM_LORA
//Paramètres
#define RF_FREQUENCY 868000000 //Hz : Fréquence de travail pour UE
#define TX_OUTPUT_POWER 14 //dBm : puissance de sortie du signal
#define LORA_BANDWIDTH 1 // 0:125 kHz de BP
#define LORA_SPREADING_FACTOR 10 // [SF7..SF12] Portée du débit. grande portée inutile
#define LORA_CODINGRATE 1
#define LORA_PREAMBLE_LENGTH 8 // Same for Tx and Rx
#define LORA_SYMBOL_TIMEOUT 5 // Symbols
#define LORA_FIX_LENGTH_PAYLOAD_ON false
|
78cb1342
rcavalie
transmission rece...
|
29
|
#define LORA_FHSS_ENABLED false //true initial
|
8c2393cd
rcavalie
travail reception...
|
30
31
32
33
34
|
#define LORA_NB_SYMB_HOP 4
#define LORA_IQ_INVERSION_ON false
#define LORA_CRC_ENABLED true
#define RX_TIMEOUT_VALUE 0 // in ms
#define BUFFER_SIZE 32 // Define the payload size here
|
16ccbfc6
rcavalie
modification des ...
|
35
|
#define TRAME_SIZE 18
|
8c2393cd
rcavalie
travail reception...
|
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
|
////////////////////////////////////////////////////////////////////////////////
////////////////////////////////////////////////////////////////////////////////
//Variables globales
typedef enum
{
LOWPOWER = 0,
IDLE,
RX,
RX_TIMEOUT,
RX_ERROR,
CAD,
CAD_DONE
}AppStates_t;
volatile AppStates_t State = LOWPOWER;
static RadioEvents_t RadioEvents;
SX1276MB1xAS Radio( NULL );
uint16_t BufferSize = BUFFER_SIZE;
uint8_t Buffer[BUFFER_SIZE];
int16_t RssiValue = 0.0;
int8_t SnrValue = 0.0;
|
16ccbfc6
rcavalie
modification des ...
|
58
|
uint8_t receptMsg[TRAME_SIZE];
|
8c2393cd
rcavalie
travail reception...
|
59
60
61
|
////////////////////////////////////////////////////////////////////////////////
////////////////////////////////////////////////////////////////////////////////
|
b0846b68
rcavalie
communication en ...
|
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
|
//Fonctions utiles
void OnRxDone( uint8_t *payload, uint16_t size, int16_t rssi, int8_t snr )
{
Radio.SetChannel( HoppingFrequencies[0] );
Radio.Sleep( );
BufferSize = size;
memcpy( Buffer, payload, BufferSize );
RssiValue = rssi;
SnrValue = snr;
State = RX;
debug_if( DEBUG_MESSAGE, "> OnRxDone\n\r" );
}
void OnRxTimeout( void )
{
Radio.SetChannel( HoppingFrequencies[0] );
Radio.Sleep( );
Buffer[BufferSize] = 0;
State = RX_TIMEOUT;
debug_if( DEBUG_MESSAGE, "> OnRxTimeout\n\r" );
}
void OnRxError( void )
{
Radio.SetChannel( HoppingFrequencies[0] );
Radio.Sleep( );
State = RX_ERROR;
debug_if( DEBUG_MESSAGE, "> OnRxError\n\r" );
}
void OnFhssChangeChannel( uint8_t channelIndex )
{
Radio.SetChannel( HoppingFrequencies[channelIndex] );
debug_if( DEBUG_MESSAGE, "F%d-", channelIndex );
}
////////////////////////////////////////////////////////////////////////////////
////////////////////////////////////////////////////////////////////////////////
|
78cb1342
rcavalie
transmission rece...
|
100
101
102
103
104
105
106
107
108
|
void TrameComp()
{
//Création d'une trame de comparaison pour vérifier si l'id de l'emetteur est bonne
/*
[1...] : ID de l'emetteur
[...] : ID du recepteur cible
[...] : Température communiquée ici 20 pour l'exemple
*/
//Converti en ASCII
|
16ccbfc6
rcavalie
modification des ...
|
109
110
111
112
113
114
115
|
receptMsg[0] = 0x7C; //emetteur |
receptMsg[1] = 0x46; //emetteur F
receptMsg[2] = 0x33; //emetteur 3
receptMsg[3] = 0x30; //emetteur 0
receptMsg[4] = 0x33; //emetteur 3
receptMsg[5] = 0x52; //emetteur R
receptMsg[6] = 0x45; //emetteur E
|
78cb1342
rcavalie
transmission rece...
|
116
|
//
|
16ccbfc6
rcavalie
modification des ...
|
117
118
119
120
121
|
receptMsg[7] = 0x46; //recepteur F
receptMsg[8] = 0x30; //recepteur 0
receptMsg[9] = 0x39; //recepteur 9
receptMsg[10] = 0x31; //recepteur 1
receptMsg[11] = 0x43; //recepteur C
|
78cb1342
rcavalie
transmission rece...
|
122
|
//
|
16ccbfc6
rcavalie
modification des ...
|
123
124
125
126
127
128
129
|
receptMsg[12] = 0x32; //temperature non vérifiee
receptMsg[13] = 0x31; //temperature non verifiee
receptMsg[14] = 0x7C; //emetteur |
//
receptMsg[15] = 0x30; //cpt non vérifé
receptMsg[16] = 0x30; //cpt non vérifié
receptMsg[17] = 0x30; //cpt non vérifé
|
78cb1342
rcavalie
transmission rece...
|
130
131
132
133
|
}
////////////////////////////////////////////////////////////////////////////////
////////////////////////////////////////////////////////////////////////////////
|
8c2393cd
rcavalie
travail reception...
|
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
|
//Main réception
int main( void )
{
debug("\nRecepteur SX1276 \n\n\r");
// Initialize Radio driver
RadioEvents.RxDone = OnRxDone;
RadioEvents.RxError = OnRxError;
RadioEvents.RxTimeout = OnRxTimeout;
RadioEvents.FhssChangeChannel = OnFhssChangeChannel;
Radio.Init(&RadioEvents);
//Véification de la communication avec la board
while(Radio.Read(REG_VERSION) == 0x00)
{
debug("Aucune radio detectee\n\r", NULL);
wait(1);
}
//Checking du matériel connecté
debug_if( ( DEBUG_MESSAGE & ( Radio.DetectBoardType( ) == SX1276MB1LAS ) ), "\n\r Materiel detecte : SX1276MB1LAS \n\r" );
debug_if( ( DEBUG_MESSAGE & ( Radio.DetectBoardType( ) == SX1276MB1MAS ) ), "\n\r Materiel detecte : SX1276MB1MAS \n\r" );
//Paramétrage du canal
Radio.SetChannel( HoppingFrequencies[0] );
#if USE_MODEM_LORA == 1
debug_if( LORA_FHSS_ENABLED, "\n\n\r > LORA FHSS Mode < \n\n\r" );
debug_if( !LORA_FHSS_ENABLED, "\n\n\r > LORA Mode < \n\n\r" );
Radio.SetRxConfig( MODEM_LORA, LORA_BANDWIDTH, LORA_SPREADING_FACTOR,
LORA_CODINGRATE, 0, LORA_PREAMBLE_LENGTH,
LORA_SYMBOL_TIMEOUT, LORA_FIX_LENGTH_PAYLOAD_ON, 0,
LORA_CRC_ENABLED, LORA_FHSS_ENABLED, LORA_NB_SYMB_HOP,
LORA_IQ_INVERSION_ON, true );
#else
#error "Aucun modem defini"
#endif
|
78cb1342
rcavalie
transmission rece...
|
174
175
176
|
TrameComp();
debug("Reception en cours...\r\n");
debug("Etat initial du Buffer : %s\r\n",(char*)Buffer);
|
8c2393cd
rcavalie
travail reception...
|
177
178
179
|
while(1)
{
|
b0846b68
rcavalie
communication en ...
|
180
|
Radio.Rx(RX_TIMEOUT_VALUE); //Reception mode en continu car TIME_OUT_VALUE = 0
|
8c2393cd
rcavalie
travail reception...
|
181
182
|
if( BufferSize > 0 )
{
|
16ccbfc6
rcavalie
modification des ...
|
183
|
if(strncmp((const char*)Buffer, (const char*)receptMsg, TRAME_SIZE-6) == 0) //-2 pour ne vérifier que l'entete
|
8c2393cd
rcavalie
travail reception...
|
184
|
{
|
50838d0a
rcavalie
processus d'affic...
|
185
|
//Buffer de données
|
757b04ad
rcavalie
création des data...
|
186
|
debug("%s\n",(char*)Buffer);
|
ec8f6a65
rcavalie
enregistrement du...
|
187
188
|
//Puissance de reception du signal
debug("%d\n",RssiValue);
|
757b04ad
rcavalie
création des data...
|
189
|
//PROGRAMME PYTHON recorder.py POUR ENREGISTRER LES DONNEES sortant du port série
|
b0846b68
rcavalie
communication en ...
|
190
191
|
//il faut vider le buffer
memset (Buffer, NULL, BUFFER_SIZE);
|
8c2393cd
rcavalie
travail reception...
|
192
|
}
|
16ccbfc6
rcavalie
modification des ...
|
193
|
wait_ms(1000);
|
8c2393cd
rcavalie
travail reception...
|
194
195
196
197
|
}
}
}
////////////////////////////////////////////////////////////////////////////////
|