Code comments
This commit is contained in:
parent
efdc4d6a6c
commit
bfa0b35d86
|
@ -1,9 +1,32 @@
|
|||
/* pavan changes */
|
||||
#include <gtk/gtk.h>
|
||||
/* variables declared of attack_detect function */
|
||||
/* -----------------------------------------------------------------------------
|
||||
* Attack_detect.h
|
||||
*
|
||||
* iPDC - Phasor Data Concentrator
|
||||
*
|
||||
* Copyright (C) 2022-2023 Nitesh Pandit
|
||||
* Copyright (C) 2022-2023 Kedar V. Khandeparkar
|
||||
*
|
||||
* This program is free software; you can redistribute it and/or
|
||||
* modify it under the terms of the GNU General Public License
|
||||
* as published by the Free Software Foundation; either version 2
|
||||
* of the License, or (at your option) any later version.
|
||||
*
|
||||
* This program is distributed in the hope that it will be useful,
|
||||
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||||
* GNU General Public License for more details.
|
||||
*
|
||||
* You should have received a copy of the GNU General Public License
|
||||
* along with this program; if not, write to the Free Software
|
||||
* Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.
|
||||
*
|
||||
* Authors:
|
||||
* M V Karthik <mvkarthik@gmail.com>
|
||||
* Pavan Kumar V Patil <pavanvpatil01@gmail.com>
|
||||
*
|
||||
* ----------------------------------------------------------------------------- */
|
||||
|
||||
/* function declared */
|
||||
#include <gtk/gtk.h>
|
||||
gboolean attack_detect_freq(struct data_frame *df);
|
||||
gboolean attack_detect_vol(struct data_frame *df);
|
||||
gboolean attack_detect_freq_vol(struct data_frame *df);
|
||||
/* pavan changes */
|
|
@ -1,5 +1,31 @@
|
|||
/* -----------------------------------------------------------------------------
|
||||
* Dynamic_time_warping.h
|
||||
*
|
||||
* iPDC - Phasor Data Concentrator
|
||||
*
|
||||
* Copyright (C) 2022-2023 Nitesh Pandit
|
||||
* Copyright (C) 2022-2023 Kedar V. Khandeparkar
|
||||
*
|
||||
* This program is free software; you can redistribute it and/or
|
||||
* modify it under the terms of the GNU General Public License
|
||||
* as published by the Free Software Foundation; either version 2
|
||||
* of the License, or (at your option) any later version.
|
||||
*
|
||||
* This program is distributed in the hope that it will be useful,
|
||||
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||||
* GNU General Public License for more details.
|
||||
*
|
||||
* You should have received a copy of the GNU General Public License
|
||||
* along with this program; if not, write to the Free Software
|
||||
* Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.
|
||||
*
|
||||
* Authors:
|
||||
* M V Karthik <mvkarthik@gmail.com>
|
||||
* Pavan Kumar V Patil <pavanvpatil01@gmail.com>
|
||||
*
|
||||
* ----------------------------------------------------------------------------- */
|
||||
|
||||
/*pavan changes*/
|
||||
int DTWfreqDistance(struct data_frame *df);
|
||||
|
||||
int DTWvolDistance(struct data_frame *df);
|
||||
|
|
|
@ -1,10 +1,31 @@
|
|||
/*Pavan Changes*/
|
||||
/* -----------------------------------------------------------------------------
|
||||
* Kmeans.h
|
||||
*
|
||||
* iPDC - Phasor Data Concentrator
|
||||
*
|
||||
* Copyright (C) 2022-2023 Nitesh Pandit
|
||||
* Copyright (C) 2022-2023 Kedar V. Khandeparkar
|
||||
*
|
||||
* This program is free software; you can redistribute it and/or
|
||||
* modify it under the terms of the GNU General Public License
|
||||
* as published by the Free Software Foundation; either version 2
|
||||
* of the License, or (at your option) any later version.
|
||||
*
|
||||
* This program is distributed in the hope that it will be useful,
|
||||
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||||
* GNU General Public License for more details.
|
||||
*
|
||||
* You should have received a copy of the GNU General Public License
|
||||
* along with this program; if not, write to the Free Software
|
||||
* Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.
|
||||
*
|
||||
* Authors:
|
||||
* M V Karthik <mvkarthik@gmail.com>
|
||||
* Pavan Kumar V Patil <pavanvpatil01@gmail.com>
|
||||
*
|
||||
* ----------------------------------------------------------------------------- */
|
||||
|
||||
#include <gtk/gtk.h>
|
||||
// intial variables
|
||||
|
||||
|
||||
|
||||
//function declaration
|
||||
gboolean kmeans(struct data_frame *df);
|
||||
|
||||
/*Pavan Changes*/
|
|
@ -1,3 +1,31 @@
|
|||
/* -----------------------------------------------------------------------------
|
||||
* Kmeans2.h
|
||||
*
|
||||
* iPDC - Phasor Data Concentrator
|
||||
*
|
||||
* Copyright (C) 2022-2023 Nitesh Pandit
|
||||
* Copyright (C) 2022-2023 Kedar V. Khandeparkar
|
||||
*
|
||||
* This program is free software; you can redistribute it and/or
|
||||
* modify it under the terms of the GNU General Public License
|
||||
* as published by the Free Software Foundation; either version 2
|
||||
* of the License, or (at your option) any later version.
|
||||
*
|
||||
* This program is distributed in the hope that it will be useful,
|
||||
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||||
* GNU General Public License for more details.
|
||||
*
|
||||
* You should have received a copy of the GNU General Public License
|
||||
* along with this program; if not, write to the Free Software
|
||||
* Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.
|
||||
*
|
||||
* Authors:
|
||||
* M V Karthik <mvkarthik@gmail.com>
|
||||
* Pavan Kumar V Patil <pavanvpatil01@gmail.com>
|
||||
*
|
||||
* ----------------------------------------------------------------------------- */
|
||||
|
||||
int *getRandoms(int lower, int upper, int count);
|
||||
long double distance(struct Point *A, struct Point *B);
|
||||
bool Kmeans2(struct data_frame *df);
|
||||
|
|
|
@ -1,8 +1,37 @@
|
|||
/* -----------------------------------------------------------------------------
|
||||
* data_vis.h
|
||||
*
|
||||
* iPDC - Phasor Data Concentrator
|
||||
*
|
||||
* Copyright (C) 2022-2023 Nitesh Pandit
|
||||
* Copyright (C) 2022-2023 Kedar V. Khandeparkar
|
||||
*
|
||||
* This program is free software; you can redistribute it and/or
|
||||
* modify it under the terms of the GNU General Public License
|
||||
* as published by the Free Software Foundation; either version 2
|
||||
* of the License, or (at your option) any later version.
|
||||
*
|
||||
* This program is distributed in the hope that it will be useful,
|
||||
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||||
* GNU General Public License for more details.
|
||||
*
|
||||
* You should have received a copy of the GNU General Public License
|
||||
* along with this program; if not, write to the Free Software
|
||||
* Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.
|
||||
*
|
||||
* Authors:
|
||||
* M V Karthik <mvkarthik@gmail.com>
|
||||
* Pavan Kumar V Patil <pavanvpatil01@gmail.com>
|
||||
*
|
||||
* ----------------------------------------------------------------------------- */
|
||||
|
||||
#include <gtk/gtk.h>
|
||||
#include <osm-gps-map.h>
|
||||
#include "livechart.h"
|
||||
|
||||
typedef struct{
|
||||
typedef struct
|
||||
{
|
||||
OsmGpsMap *util_map;
|
||||
GdkPixbuf *g_red_image;
|
||||
GdkPixbuf *g_green_image;
|
||||
|
@ -10,7 +39,8 @@ typedef struct{
|
|||
int current_selection;
|
||||
} myParameters;
|
||||
|
||||
struct vis_data{
|
||||
struct vis_data
|
||||
{
|
||||
int id;
|
||||
float lat;
|
||||
float lon;
|
||||
|
|
|
@ -1,3 +1,31 @@
|
|||
/* -----------------------------------------------------------------------------
|
||||
* utility_tools.h
|
||||
*
|
||||
* iPDC - Phasor Data Concentrator
|
||||
*
|
||||
* Copyright (C) 2022-2023 Nitesh Pandit
|
||||
* Copyright (C) 2022-2023 Kedar V. Khandeparkar
|
||||
*
|
||||
* This program is free software; you can redistribute it and/or
|
||||
* modify it under the terms of the GNU General Public License
|
||||
* as published by the Free Software Foundation; either version 2
|
||||
* of the License, or (at your option) any later version.
|
||||
*
|
||||
* This program is distributed in the hope that it will be useful,
|
||||
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||||
* GNU General Public License for more details.
|
||||
*
|
||||
* You should have received a copy of the GNU General Public License
|
||||
* along with this program; if not, write to the Free Software
|
||||
* Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.
|
||||
*
|
||||
* Authors:
|
||||
* M V Karthik <mvkarthik@gmail.com>
|
||||
* Pavan Kumar V Patil <pavanvpatil01@gmail.com>
|
||||
*
|
||||
* ----------------------------------------------------------------------------- */
|
||||
|
||||
#include <stdio.h>
|
||||
#include <gtk/gtk.h>
|
||||
#include "osm-gps-map.h"
|
||||
|
@ -53,6 +81,4 @@ int curr_measurement;
|
|||
int algorithm;
|
||||
int dimmension;
|
||||
|
||||
|
||||
|
||||
void utility_tools(GtkButton *but, gpointer udata);
|
|
@ -1,4 +1,31 @@
|
|||
/* pavan changes */
|
||||
/* -----------------------------------------------------------------------------
|
||||
* Attack_detect.c
|
||||
*
|
||||
* iPDC - Phasor Data Concentrator
|
||||
*
|
||||
* Copyright (C) 2022-2023 Nitesh Pandit
|
||||
* Copyright (C) 2022-2023 Kedar V. Khandeparkar
|
||||
*
|
||||
* This program is free software; you can redistribute it and/or
|
||||
* modify it under the terms of the GNU General Public License
|
||||
* as published by the Free Software Foundation; either version 2
|
||||
* of the License, or (at your option) any later version.
|
||||
*
|
||||
* This program is distributed in the hope that it will be useful,
|
||||
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||||
* GNU General Public License for more details.
|
||||
*
|
||||
* You should have received a copy of the GNU General Public License
|
||||
* along with this program; if not, write to the Free Software
|
||||
* Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.
|
||||
*
|
||||
* Authors:
|
||||
* M V Karthik <mvkarthik@gmail.com>
|
||||
* Pavan Kumar V Patil <pavanvpatil01@gmail.com>
|
||||
*
|
||||
* ----------------------------------------------------------------------------- */
|
||||
|
||||
#include <time.h>
|
||||
#include <stdio.h>
|
||||
#include <stdlib.h>
|
||||
|
|
|
@ -1,3 +1,31 @@
|
|||
/* -----------------------------------------------------------------------------
|
||||
* Dynamic_time_warping.c
|
||||
*
|
||||
* iPDC - Phasor Data Concentrator
|
||||
*
|
||||
* Copyright (C) 2022-2023 Nitesh Pandit
|
||||
* Copyright (C) 2022-2023 Kedar V. Khandeparkar
|
||||
*
|
||||
* This program is free software; you can redistribute it and/or
|
||||
* modify it under the terms of the GNU General Public License
|
||||
* as published by the Free Software Foundation; either version 2
|
||||
* of the License, or (at your option) any later version.
|
||||
*
|
||||
* This program is distributed in the hope that it will be useful,
|
||||
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||||
* GNU General Public License for more details.
|
||||
*
|
||||
* You should have received a copy of the GNU General Public License
|
||||
* along with this program; if not, write to the Free Software
|
||||
* Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.
|
||||
*
|
||||
* Authors:
|
||||
* M V Karthik <mvkarthik@gmail.com>
|
||||
* Pavan Kumar V Patil <pavanvpatil01@gmail.com>
|
||||
*
|
||||
* ----------------------------------------------------------------------------- */
|
||||
|
||||
#include "parser.h"
|
||||
#include <stdio.h>
|
||||
#include <math.h>
|
||||
|
|
|
@ -1,4 +1,30 @@
|
|||
/*Pavan Changes*/
|
||||
/* -----------------------------------------------------------------------------
|
||||
* Kmeans.c
|
||||
*
|
||||
* iPDC - Phasor Data Concentrator
|
||||
*
|
||||
* Copyright (C) 2022-2023 Nitesh Pandit
|
||||
* Copyright (C) 2022-2023 Kedar V. Khandeparkar
|
||||
*
|
||||
* This program is free software; you can redistribute it and/or
|
||||
* modify it under the terms of the GNU General Public License
|
||||
* as published by the Free Software Foundation; either version 2
|
||||
* of the License, or (at your option) any later version.
|
||||
*
|
||||
* This program is distributed in the hope that it will be useful,
|
||||
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||||
* GNU General Public License for more details.
|
||||
*
|
||||
* You should have received a copy of the GNU General Public License
|
||||
* along with this program; if not, write to the Free Software
|
||||
* Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.
|
||||
*
|
||||
* Authors:
|
||||
* M V Karthik <mvkarthik@gmail.com>
|
||||
* Pavan Kumar V Patil <pavanvpatil01@gmail.com>
|
||||
*
|
||||
* ----------------------------------------------------------------------------- */
|
||||
|
||||
#include "parser.h"
|
||||
#include <stdlib.h>
|
||||
|
@ -99,5 +125,3 @@ gboolean kmeans(struct data_frame *df)
|
|||
}
|
||||
}
|
||||
}
|
||||
|
||||
/*Pavan Changes*/
|
|
@ -1,3 +1,31 @@
|
|||
/* -----------------------------------------------------------------------------
|
||||
* Kmeans2.c
|
||||
*
|
||||
* iPDC - Phasor Data Concentrator
|
||||
*
|
||||
* Copyright (C) 2022-2023 Nitesh Pandit
|
||||
* Copyright (C) 2022-2023 Kedar V. Khandeparkar
|
||||
*
|
||||
* This program is free software; you can redistribute it and/or
|
||||
* modify it under the terms of the GNU General Public License
|
||||
* as published by the Free Software Foundation; either version 2
|
||||
* of the License, or (at your option) any later version.
|
||||
*
|
||||
* This program is distributed in the hope that it will be useful,
|
||||
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||||
* GNU General Public License for more details.
|
||||
*
|
||||
* You should have received a copy of the GNU General Public License
|
||||
* along with this program; if not, write to the Free Software
|
||||
* Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.
|
||||
*
|
||||
* Authors:
|
||||
* M V Karthik <mvkarthik@gmail.com>
|
||||
* Pavan Kumar V Patil <pavanvpatil01@gmail.com>
|
||||
*
|
||||
* ----------------------------------------------------------------------------- */
|
||||
|
||||
#include "parser.h"
|
||||
#include <stdlib.h>
|
||||
#include <stdio.h>
|
||||
|
|
|
@ -1,3 +1,31 @@
|
|||
/* -----------------------------------------------------------------------------
|
||||
* data_vis.c
|
||||
*
|
||||
* iPDC - Phasor Data Concentrator
|
||||
*
|
||||
* Copyright (C) 2022-2023 Nitesh Pandit
|
||||
* Copyright (C) 2022-2023 Kedar V. Khandeparkar
|
||||
*
|
||||
* This program is free software; you can redistribute it and/or
|
||||
* modify it under the terms of the GNU General Public License
|
||||
* as published by the Free Software Foundation; either version 2
|
||||
* of the License, or (at your option) any later version.
|
||||
*
|
||||
* This program is distributed in the hope that it will be useful,
|
||||
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||||
* GNU General Public License for more details.
|
||||
*
|
||||
* You should have received a copy of the GNU General Public License
|
||||
* along with this program; if not, write to the Free Software
|
||||
* Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.
|
||||
*
|
||||
* Authors:
|
||||
* M V Karthik <mvkarthik@gmail.com>
|
||||
* Pavan Kumar V Patil <pavanvpatil01@gmail.com>
|
||||
*
|
||||
* ----------------------------------------------------------------------------- */
|
||||
|
||||
#include <stdlib.h>
|
||||
#include <stdio.h>
|
||||
#include <stdbool.h>
|
||||
|
@ -16,10 +44,10 @@
|
|||
#include "utility_tools.h"
|
||||
#include "Kmeans2.h"
|
||||
|
||||
|
||||
int loops = 0;
|
||||
|
||||
gboolean update_vis(gpointer* pars){
|
||||
gboolean update_vis(gpointer *pars)
|
||||
{
|
||||
int match = 0, id, cfg_match = 0;
|
||||
myParameters *parameters = (myParameters *)pars;
|
||||
struct cfg_frame *temp_cfg;
|
||||
|
@ -29,7 +57,8 @@ gboolean update_vis(gpointer* pars){
|
|||
struct Lower_Layer_Details *LLptr;
|
||||
struct vis_data *vis_ptr;
|
||||
|
||||
if (df == NULL){
|
||||
if (df == NULL)
|
||||
{
|
||||
pthread_mutex_unlock(&mutex_on_TSB);
|
||||
return TRUE;
|
||||
}
|
||||
|
@ -37,32 +66,40 @@ gboolean update_vis(gpointer* pars){
|
|||
int i = 0, k = 0;
|
||||
float freq, vol_magnitude, angle, dfreq;
|
||||
unsigned char freq_fmt, anal_fmt, phas_fmt, polar_fmt;
|
||||
while (df!=NULL){
|
||||
while (df != NULL)
|
||||
{
|
||||
float lat;
|
||||
float lon;
|
||||
loops++;
|
||||
id = to_intconvertor(df->idcode);
|
||||
pthread_mutex_lock(&mutex_cfg);
|
||||
temp_cfg = cfgfirst;
|
||||
while(temp_cfg != NULL){
|
||||
if(id == to_intconvertor(temp_cfg->idcode)){
|
||||
while (temp_cfg != NULL)
|
||||
{
|
||||
if (id == to_intconvertor(temp_cfg->idcode))
|
||||
{
|
||||
cfg_match = 1;
|
||||
freq_fmt = temp_cfg->pmu[0]->fmt->freq;
|
||||
anal_fmt = temp_cfg->pmu[0]->fmt->analog;
|
||||
phas_fmt = temp_cfg->pmu[0]->fmt->phasor;
|
||||
polar_fmt = temp_cfg->pmu[0]->fmt->polar;
|
||||
break;
|
||||
} else {
|
||||
}
|
||||
else
|
||||
{
|
||||
temp_cfg = temp_cfg->cfgnext;
|
||||
}
|
||||
}
|
||||
pthread_mutex_unlock(&mutex_cfg);
|
||||
|
||||
// get data from df.
|
||||
if(freq_fmt == '1'){
|
||||
if (freq_fmt == '1')
|
||||
{
|
||||
freq = decode_ieee_single(df->dpmu[i]->freq);
|
||||
printf("freq = %f\n", freq);
|
||||
}else{
|
||||
}
|
||||
else
|
||||
{
|
||||
freq = to_intconvertor(df->dpmu[i]->freq) * 1e-3 + 50;
|
||||
printf("freq = %f\n", freq);
|
||||
}
|
||||
|
@ -76,8 +113,10 @@ gboolean update_vis(gpointer* pars){
|
|||
|
||||
vis_ptr = vis_data_head;
|
||||
match = 0;
|
||||
while(vis_ptr != NULL){
|
||||
if(vis_ptr->id == id){
|
||||
while (vis_ptr != NULL)
|
||||
{
|
||||
if (vis_ptr->id == id)
|
||||
{
|
||||
match = 1;
|
||||
break;
|
||||
}
|
||||
|
@ -91,78 +130,136 @@ gboolean update_vis(gpointer* pars){
|
|||
live_chart_serie_add(vis_ptr->serie_vol, vol_magnitude);
|
||||
live_chart_serie_add(vis_ptr->serie_dfreq, dfreq);
|
||||
|
||||
if(match == 1 && cfg_match == 1){
|
||||
if(vis_ptr->last_image != 0){
|
||||
if (match == 1 && cfg_match == 1)
|
||||
{
|
||||
if (vis_ptr->last_image != 0)
|
||||
{
|
||||
osm_gps_map_image_remove(parameters->util_map, vis_ptr->last_image);
|
||||
}
|
||||
|
||||
if(curr_measurement == 0){
|
||||
if(vol_magnitude > 65600 || vol_magnitude < 65300){
|
||||
vis_ptr->last_image = osm_gps_map_image_add(parameters->util_map, lat, lon, parameters->g_red_image);
|
||||
}else{
|
||||
vis_ptr->last_image = osm_gps_map_image_add(parameters->util_map, lat, lon, parameters->g_green_image);
|
||||
}
|
||||
}else if(curr_measurement == 1){
|
||||
if (freq > 50.3){
|
||||
vis_ptr->last_image = osm_gps_map_image_add(parameters->util_map,lat, lon, parameters->g_green_image);
|
||||
}else{
|
||||
if (curr_measurement == 0)
|
||||
{
|
||||
if (vol_magnitude > 65600 || vol_magnitude < 65300)
|
||||
{
|
||||
vis_ptr->last_image = osm_gps_map_image_add(parameters->util_map, lat, lon, parameters->g_red_image);
|
||||
}
|
||||
}else if(curr_measurement == 2){
|
||||
if (dfreq < 0.5){
|
||||
vis_ptr->last_image = osm_gps_map_image_add(parameters->util_map,lat, lon, parameters->g_green_image);
|
||||
}else{
|
||||
vis_ptr->last_image = osm_gps_map_image_add(parameters->util_map,lat, lon, parameters->g_red_image);
|
||||
}
|
||||
}else if(curr_measurement == 3){
|
||||
if(algorithm==0 && dimmension == 0){
|
||||
if (!attack_detect_freq(df)){
|
||||
vis_ptr->last_image = osm_gps_map_image_add(parameters->util_map,lat, lon, parameters->g_red_image);
|
||||
}else{
|
||||
else
|
||||
{
|
||||
vis_ptr->last_image = osm_gps_map_image_add(parameters->util_map, lat, lon, parameters->g_green_image);
|
||||
}
|
||||
}else if (algorithm==0 && dimmension == 1){
|
||||
if (!attack_detect_vol(df)){
|
||||
vis_ptr->last_image = osm_gps_map_image_add(parameters->util_map,lat, lon, parameters->g_red_image);
|
||||
}else{
|
||||
}
|
||||
else if (curr_measurement == 1)
|
||||
{
|
||||
if (freq > 50.3)
|
||||
{
|
||||
vis_ptr->last_image = osm_gps_map_image_add(parameters->util_map, lat, lon, parameters->g_green_image);
|
||||
}
|
||||
}else if (algorithm==0 && dimmension == 2){
|
||||
if (!attack_detect_freq_vol(df)){
|
||||
else
|
||||
{
|
||||
vis_ptr->last_image = osm_gps_map_image_add(parameters->util_map, lat, lon, parameters->g_red_image);
|
||||
}else{
|
||||
}
|
||||
}
|
||||
else if (curr_measurement == 2)
|
||||
{
|
||||
if (dfreq < 0.5)
|
||||
{
|
||||
vis_ptr->last_image = osm_gps_map_image_add(parameters->util_map, lat, lon, parameters->g_green_image);
|
||||
}
|
||||
}else if (algorithm==1 && dimmension == 0){
|
||||
if(!kmeans(df)){
|
||||
else
|
||||
{
|
||||
vis_ptr->last_image = osm_gps_map_image_add(parameters->util_map, lat, lon, parameters->g_red_image);
|
||||
}else{
|
||||
}
|
||||
}
|
||||
else if (curr_measurement == 3)
|
||||
{
|
||||
if (algorithm == 0 && dimmension == 0)
|
||||
{
|
||||
if (!attack_detect_freq(df))
|
||||
{
|
||||
vis_ptr->last_image = osm_gps_map_image_add(parameters->util_map, lat, lon, parameters->g_red_image);
|
||||
}
|
||||
else
|
||||
{
|
||||
vis_ptr->last_image = osm_gps_map_image_add(parameters->util_map, lat, lon, parameters->g_green_image);
|
||||
}
|
||||
}else if (algorithm==1 && dimmension == 1){
|
||||
|
||||
}else if (algorithm==1 && dimmension == 2){
|
||||
if(!Kmeans2(df)){
|
||||
}
|
||||
else if (algorithm == 0 && dimmension == 1)
|
||||
{
|
||||
if (!attack_detect_vol(df))
|
||||
{
|
||||
vis_ptr->last_image = osm_gps_map_image_add(parameters->util_map, lat, lon, parameters->g_red_image);
|
||||
}else{
|
||||
}
|
||||
else
|
||||
{
|
||||
vis_ptr->last_image = osm_gps_map_image_add(parameters->util_map, lat, lon, parameters->g_green_image);
|
||||
}
|
||||
}else if (algorithm==2 && dimmension == 0){
|
||||
if(!DTWfreqDistance(df)){
|
||||
}
|
||||
else if (algorithm == 0 && dimmension == 2)
|
||||
{
|
||||
if (!attack_detect_freq_vol(df))
|
||||
{
|
||||
vis_ptr->last_image = osm_gps_map_image_add(parameters->util_map, lat, lon, parameters->g_red_image);
|
||||
}else{
|
||||
}
|
||||
else
|
||||
{
|
||||
vis_ptr->last_image = osm_gps_map_image_add(parameters->util_map, lat, lon, parameters->g_green_image);
|
||||
}
|
||||
}else if (algorithm==2 && dimmension == 1){
|
||||
if(!DTWvolDistance(df)){
|
||||
}
|
||||
else if (algorithm == 1 && dimmension == 0)
|
||||
{
|
||||
if (!kmeans(df))
|
||||
{
|
||||
vis_ptr->last_image = osm_gps_map_image_add(parameters->util_map, lat, lon, parameters->g_red_image);
|
||||
}else{
|
||||
}
|
||||
else
|
||||
{
|
||||
vis_ptr->last_image = osm_gps_map_image_add(parameters->util_map, lat, lon, parameters->g_green_image);
|
||||
}
|
||||
}else if (algorithm==2 && dimmension == 2){
|
||||
if(!DTWfreqvolDistance(df)){
|
||||
}
|
||||
else if (algorithm == 1 && dimmension == 1)
|
||||
{
|
||||
}
|
||||
else if (algorithm == 1 && dimmension == 2)
|
||||
{
|
||||
if (!Kmeans2(df))
|
||||
{
|
||||
vis_ptr->last_image = osm_gps_map_image_add(parameters->util_map, lat, lon, parameters->g_red_image);
|
||||
}else{
|
||||
}
|
||||
else
|
||||
{
|
||||
vis_ptr->last_image = osm_gps_map_image_add(parameters->util_map, lat, lon, parameters->g_green_image);
|
||||
}
|
||||
}
|
||||
else if (algorithm == 2 && dimmension == 0)
|
||||
{
|
||||
if (!DTWfreqDistance(df))
|
||||
{
|
||||
vis_ptr->last_image = osm_gps_map_image_add(parameters->util_map, lat, lon, parameters->g_red_image);
|
||||
}
|
||||
else
|
||||
{
|
||||
vis_ptr->last_image = osm_gps_map_image_add(parameters->util_map, lat, lon, parameters->g_green_image);
|
||||
}
|
||||
}
|
||||
else if (algorithm == 2 && dimmension == 1)
|
||||
{
|
||||
if (!DTWvolDistance(df))
|
||||
{
|
||||
vis_ptr->last_image = osm_gps_map_image_add(parameters->util_map, lat, lon, parameters->g_red_image);
|
||||
}
|
||||
else
|
||||
{
|
||||
vis_ptr->last_image = osm_gps_map_image_add(parameters->util_map, lat, lon, parameters->g_green_image);
|
||||
}
|
||||
}
|
||||
else if (algorithm == 2 && dimmension == 2)
|
||||
{
|
||||
if (!DTWfreqvolDistance(df))
|
||||
{
|
||||
vis_ptr->last_image = osm_gps_map_image_add(parameters->util_map, lat, lon, parameters->g_red_image);
|
||||
}
|
||||
else
|
||||
{
|
||||
vis_ptr->last_image = osm_gps_map_image_add(parameters->util_map, lat, lon, parameters->g_green_image);
|
||||
}
|
||||
}
|
||||
|
@ -176,4 +273,3 @@ gboolean update_vis(gpointer* pars){
|
|||
gtk_widget_queue_draw(GTK_WIDGET(parameters->util_map));
|
||||
return TRUE;
|
||||
}
|
||||
|
||||
|
|
|
@ -1,3 +1,31 @@
|
|||
/* -----------------------------------------------------------------------------
|
||||
* utility_tools.c
|
||||
*
|
||||
* iPDC - Phasor Data Concentrator
|
||||
*
|
||||
* Copyright (C) 2022-2023 Nitesh Pandit
|
||||
* Copyright (C) 2022-2023 Kedar V. Khandeparkar
|
||||
*
|
||||
* This program is free software; you can redistribute it and/or
|
||||
* modify it under the terms of the GNU General Public License
|
||||
* as published by the Free Software Foundation; either version 2
|
||||
* of the License, or (at your option) any later version.
|
||||
*
|
||||
* This program is distributed in the hope that it will be useful,
|
||||
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||||
* GNU General Public License for more details.
|
||||
*
|
||||
* You should have received a copy of the GNU General Public License
|
||||
* along with this program; if not, write to the Free Software
|
||||
* Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.
|
||||
*
|
||||
* Authors:
|
||||
* M V Karthik <mvkarthik@gmail.com>
|
||||
* Pavan Kumar V Patil <pavanvpatil01@gmail.com>
|
||||
*
|
||||
* ----------------------------------------------------------------------------- */
|
||||
|
||||
#include <gtk/gtk.h>
|
||||
#include "align_sort.h"
|
||||
#include "parser.h"
|
||||
|
@ -14,11 +42,12 @@
|
|||
#define GREY_IMAGE "/usr/local/share/iPDC/grey.png"
|
||||
#define PINK_IMAGE "/usr/local/share/iPDC/pink.png"
|
||||
|
||||
|
||||
GdkRGBA getIndexColor(int index){
|
||||
GdkRGBA getIndexColor(int index)
|
||||
{
|
||||
GdkRGBA color;
|
||||
// get the color from the index mathematically
|
||||
switch(index){
|
||||
switch (index)
|
||||
{
|
||||
case 0:
|
||||
color.red = 1.0;
|
||||
color.green = 0.0;
|
||||
|
@ -113,7 +142,6 @@ GdkRGBA getIndexColor(int index){
|
|||
return color;
|
||||
}
|
||||
|
||||
|
||||
void on_window_destroy(GtkWidget *widget, gpointer data)
|
||||
{
|
||||
g_source_remove(GPOINTER_TO_UINT(data));
|
||||
|
@ -173,7 +201,6 @@ void on_frequency_clicked(GtkButton *but, gpointer udata)
|
|||
gtk_widget_hide(utdata->graph_layoutdfreq);
|
||||
gtk_widget_hide(utdata->graph_layoutvol);
|
||||
|
||||
|
||||
gtk_widget_hide(utdata->algorithm);
|
||||
gtk_widget_hide(utdata->dimmension);
|
||||
gtk_widget_hide(utdata->algo_label);
|
||||
|
@ -207,7 +234,6 @@ void on_dfreq_clicked(GtkButton *but, gpointer udata)
|
|||
gtk_widget_hide(utdata->swvol);
|
||||
gtk_widget_hide(utdata->swfreq);
|
||||
|
||||
|
||||
gtk_widget_hide(utdata->algorithm);
|
||||
gtk_widget_hide(utdata->dimmension);
|
||||
gtk_widget_hide(utdata->algo_label);
|
||||
|
@ -264,8 +290,6 @@ void set_dimm(GtkComboBox *combo, gpointer udata)
|
|||
printf("dimmension = %d\n", dimmension);
|
||||
}
|
||||
|
||||
|
||||
|
||||
// Initializes utility tools window.
|
||||
void utility_tools(GtkButton *but, gpointer udata)
|
||||
{
|
||||
|
@ -322,7 +346,6 @@ void utility_tools(GtkButton *but, gpointer udata)
|
|||
gtk_widget_set_visible(utdata->graph_layoutfreq, FALSE);
|
||||
gtk_widget_set_visible(utdata->graph_layoutdfreq, FALSE);
|
||||
|
||||
|
||||
g_signal_connect(utdata->voltage, "clicked", G_CALLBACK(on_voltage_clicked), NULL);
|
||||
g_signal_connect(utdata->frequency, "clicked", G_CALLBACK(on_frequency_clicked), NULL);
|
||||
g_signal_connect(utdata->dfreq, "clicked", G_CALLBACK(on_dfreq_clicked), NULL);
|
||||
|
@ -350,7 +373,6 @@ void utility_tools(GtkButton *but, gpointer udata)
|
|||
|
||||
gtk_container_add(utdata->map_layout, GTK_WIDGET(utdata->util_map));
|
||||
|
||||
|
||||
LiveChartConfig *config_vol = live_chart_config_new();
|
||||
live_chart_yaxis_set_unit(config_vol->y_axis, "V");
|
||||
live_chart_xaxis_set_tick_interval(config_vol->x_axis, 20);
|
||||
|
@ -369,7 +391,6 @@ void utility_tools(GtkButton *but, gpointer udata)
|
|||
|
||||
LiveChartChart *chart_freq = live_chart_chart_new(config_freq);
|
||||
|
||||
|
||||
LiveChartConfig *config_dfreq = live_chart_config_new();
|
||||
live_chart_yaxis_set_unit(config_dfreq->y_axis, "mHz");
|
||||
live_chart_xaxis_set_tick_interval(config_dfreq->x_axis, 20);
|
||||
|
@ -396,7 +417,6 @@ void utility_tools(GtkButton *but, gpointer udata)
|
|||
// declare tooltip
|
||||
gchar *tooltiptext;
|
||||
|
||||
|
||||
// iterate through the cfg frame and find the corresponding cfg frame
|
||||
while (temp_cfg != NULL)
|
||||
{
|
||||
|
@ -453,10 +473,13 @@ void utility_tools(GtkButton *but, gpointer udata)
|
|||
temp_visptr->next = NULL;
|
||||
|
||||
guint pid = g_timeout_add(20, (GSourceFunc)update_vis, data);
|
||||
if(index>0){
|
||||
if (index > 0)
|
||||
{
|
||||
centroid_latitude /= (index);
|
||||
centroid_longitude /= (index);
|
||||
}else{
|
||||
}
|
||||
else
|
||||
{
|
||||
centroid_latitude = 15;
|
||||
centroid_longitude = 74;
|
||||
}
|
||||
|
|
Can't render this file because it is too large.
|
Loading…
Reference in New Issue