Blame view

recepteur/recepteur.cpp 6.5 KB
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
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
  #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
  #define TRAME_SIZE 13
  ////////////////////////////////////////////////////////////////////////////////
  
  ////////////////////////////////////////////////////////////////////////////////
  //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;
  uint8_t receptMsg[13];
  ////////////////////////////////////////////////////////////////////////////////
  
  ////////////////////////////////////////////////////////////////////////////////
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
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
  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
      receptMsg[0] =  0x46; //emetteur F
      receptMsg[1] =  0x33; //emetteur 3
      receptMsg[2] =  0x30; //emetteur 0
      receptMsg[3] =  0x33; //emetteur 3
      receptMsg[4] =  0x52; //emetteur R
      receptMsg[5] =  0x45; //emetteur E
      //
      receptMsg[6] =  0x46; //recepteur F
      receptMsg[7] =  0x30; //recepteur 0
      receptMsg[8] =  0x39; //recepteur 9
      receptMsg[9] =  0x31; //recepteur 1
      receptMsg[10] = 0x43; //recepteur C
      //
      receptMsg[11] = 0x32; //temperature non vérifiee
      receptMsg[12] = 0x31; //temperature non verifiee
  }
  ////////////////////////////////////////////////////////////////////////////////
  
  ////////////////////////////////////////////////////////////////////////////////
8c2393cd   rcavalie   travail reception...
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
  //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...
168
169
170
          TrameComp();
          debug("Reception en cours...\r\n");
          debug("Etat initial du Buffer : %s\r\n",(char*)Buffer);
8c2393cd   rcavalie   travail reception...
171
172
173
  
          while(1)
          {
b0846b68   rcavalie   communication en ...
174
              Radio.Rx(RX_TIMEOUT_VALUE); //Reception mode en continu car TIME_OUT_VALUE = 0
8c2393cd   rcavalie   travail reception...
175
176
              if( BufferSize > 0 )
              {
78cb1342   rcavalie   transmission rece...
177
                  if(strncmp((const char*)Buffer, (const char*)receptMsg, TRAME_SIZE-2 ) == 0) //-2 pour ne vérifier que l'entete
8c2393cd   rcavalie   travail reception...
178
                  {
50838d0a   rcavalie   processus d'affic...
179
                      //Buffer de données
757b04ad   rcavalie   création des data...
180
                      debug("%s\n",(char*)Buffer);
ec8f6a65   rcavalie   enregistrement du...
181
182
                      //Puissance de reception du signal
                      debug("%d\n",RssiValue);
b0846b68   rcavalie   communication en ...
183
                      //il faut enregistrer la trame
757b04ad   rcavalie   création des data...
184
                      //PROGRAMME PYTHON recorder.py POUR ENREGISTRER LES DONNEES sortant du port série
b0846b68   rcavalie   communication en ...
185
186
                      //il faut vider le buffer
                      memset (Buffer, NULL, BUFFER_SIZE);
8c2393cd   rcavalie   travail reception...
187
                  }
ec8f6a65   rcavalie   enregistrement du...
188
                  wait_ms(500);
8c2393cd   rcavalie   travail reception...
189
190
191
192
              }
          }
  }
  ////////////////////////////////////////////////////////////////////////////////