-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathmain_map2.c
64 lines (55 loc) · 2.02 KB
/
main_map2.c
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
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
62
63
64
#include <stdlib.h>
#include <stdio.h>
#include "kd_tree.h"
#include "csv_reader.h"
#define MAX_OUTPUT_ROW_SIZE 1024
#define MAX_ROW_SIZE 513
#define READ_SPACES_FORMATTER "%[^\n]s"
char* trim(char* str){
if(str[strlen(str)-1]=='\n' || str[strlen(str)-1]=='\r'){
str[strlen(str)-1] = '\0';
}
return str;
}
int main(int argc, char** argv){
char* datafile = argv[1];
char* outputfile = argv[2];
if(argc<2){
printf("Usage ./map1 datafile outputfile < inputfile\n");
exit(0);
}
struct csv_meta_data* meta_data = get_csv_meta_data(datafile);
struct csv_reader* reader = get_csv_data_object(datafile);
KDTree *tree = get_new_kd_tree(2);
for(int i = 0; i<meta_data->records_count; i++){
char* data_line = (char*) malloc(MAX_OUTPUT_ROW_SIZE*sizeof(char));
for(int j = 0; j<meta_data->columns_count; j++){
char* formated_str = (char*) malloc(MAX_ROW_SIZE*sizeof(char));
sprintf(formated_str,"%s: %s || "
,trim(reader->data_array[i]->col_name[j])
,trim(reader->data_array[i]->col_value[j]));
strcat(data_line,formated_str);
}
char *endptr;
double *key = (double*)malloc(2*(sizeof(double))) ;
key[0] = strtod(reader->data_array[i]->col_value[8],&endptr); // X Co-ordinate
key[1] = strtod(reader->data_array[i]->col_value[9],&endptr); // Y Co-ordinate
kd_tree_insert(tree,key,(void*)data_line);
}
double x,y,radius;
while(scanf("%lf %lf %lf",&x,&y, &radius)==3){
double key[] = {x,y};
struct list *ret = find_closest_in_radius(tree,key,radius);
if(ret->size == 0){
FILE* fd = fopen(outputfile,"a+");
fprintf(fd,"%lf %lf %lf --> NOTFOUND\n",x,y,radius);
fclose(fd);
continue;
}
struct list_node *tmp = ret->head;
while(tmp){
print_list_3d((struct list*)tmp->data,x,y,radius,outputfile);
tmp = tmp->next;
}
}
}