main_simple.py 5.95 KB
"""
Created on Thu Jan 11 15:22:56 2018
@author: Robin Cavalieri 
IMA5SC - PFE 2018
P32 - Détection automatique de DoS sur réseau LoRa
Main - prédictions, affichage, vérification du trafic 
"""
###############################################################################
#LIBRAIRIES UTILES
###############################################################################
import time;
import serial;
import numpy as np;
# Réseau de neurones 
from keras.models import Sequential
from keras.layers import Dense
from keras.models import model_from_json
###############################################################################

###############################################################################
#VARIABLES GLOBALES INITIALISATION
###############################################################################
ping_mesured=0; 
rssi_mesured=0;
result=0;
puissance_read = 0;
temp_read = 0;
trame_read = [];
file_name = 'C:/Users/Utilisateur/PFE/python/datasets/data_to_pred.csv';
###############################################################################

##############################################################################
#DEFINITION DE LA LECTURE DE PORT 
##############################################################################
ser = serial.Serial(      
 #Pour Linux
 #port='/dev/ttyACM0',
 #Pour Windows
 port='COM4',
 #Vitesse de communication
 baudrate = 9600,
 #Parité 
 parity=serial.PARITY_NONE,
 #Bit de stop
 stopbits=serial.STOPBITS_ONE,
 #Taille du message 
 bytesize=serial.EIGHTBITS,
 #Out
 timeout=1
)
counter=0;
##############################################################################
    
###############################################################################
#FONCTION DE PREDICTION APPELEE DANS LE MAIN 
###############################################################################
def Predictions(data_eval):
    ###############################################################################
    #ARCHITECTURE DU RESEAU DE NEURONES par le biais de la librairie KERAS
    #ANN 
    ###############################################################################
    #Création du classifieur 
    classifier = Sequential();
    #Couche d'entrée donc avec 2 entrées, PING et DELTA_RSSI
    classifier.add(Dense(32, activation='relu', input_dim=2))
    #Couche de sortie
    classifier.add(Dense(1, activation='sigmoid'))
    ###############################################################################
    #COMPILATION
    ###############################################################################
    # optimizer : algorithme choisi pour trouver le model (le plus puissant)
    # loss : Si deux valeurs en sortie (binairie outcome) : binary_crossentropy
    classifier.compile(optimizer = 'rmsprop', loss = 'binary_crossentropy', metrics = ['accuracy']);
    ###############################################################################
    #LOAD DU TRAINING SET
    ###########################################################################
    json_file=open('C:/Users/Utilisateur/PFE/python/Training/training.json','r');
    loaded_model_json=json_file.read();
    json_file.close();
    loaded_model=model_from_json(loaded_model_json);
    loaded_model.load_weights('C:/Users/Utilisateur/PFE/python/Training/training.h5');
    ###########################################################################
    #REALISER DES PREDICTIONS
    ###########################################################################
    #Normalisation des données 
    #sc = StandardScaler();
    predictions = classifier.predict(data_eval);
    return predictions;
###############################################################################

###############################################################################
#AFFICHAGE 
###############################################################################  
def Recorder():
    cpt_trame = 0;
    global temp;
    global temp_read;
    global ping_mesured;
    global puissance_read;
    global trame_read;
    global cpt_trames;
    while(1):
        #RECUPERATION DES DONNEES
        x = ser.readline();
        if(0x46 in x and cpt_trame == 0):
            cpt_trame = cpt_trame + 1;
            temp = time.time();
        if(0x46 in x and cpt_trame >= 1):
            t2 = time.time();
            ping_mesured = (t2-temp)*1000;
            temp = t2;
            cpt_trame = cpt_trame + 1;
            #Lecture de la trame 
            trame_read = x;
            #Récupération de la température
            temp_read = (trame_read[12]-48)*10 + trame_read[13]-48;
            #Récupération du compteur de trames
            cpt_trames = (trame_read[15]-48)*100 + (trame_read[16]-48)*10 + (trame_read[17]-48);
            #Récupération de la puissance 
            x = ser.readline();
            puissance_read = (x[1]-48)*10 + x[2]-48;
    
        #SET INPUTS PREDICTION
        data_to_pred =  np.array((ping_mesured, puissance_read),dtype = np.int64); 
        data_to_pred = data_to_pred.reshape((1,2));
        
        #PREDICTION TEMPS REEL
        pred = Predictions(data_to_pred);
        
        #AFFICHAGE
        print("\n###############################\n");
        print("TRAME : "+ "".join(map(chr, trame_read))+"\n");
        print("TRAME NUM. : "+str(cpt_trames)+"\n");
        print("TEMPERATURE : "+str(temp_read)+" °C\n");
        print("PUISSANCE : "+str(puissance_read)+" dBm\n");
        print("PING : "+str(ping_mesured)+" ms\n");
        np.round(pred,0);
        if(pred==0):
            print("TRAFIC : ATTAQUE\n");
        elif(pred==1):
            print("TRAFIC : RAS\n");
        print("###############################\n");
###############################################################################

###############################################################################
#MAIN   
###############################################################################
if __name__ == '__main__':   
    Recorder();     
###############################################################################