-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathmain.c
55 lines (46 loc) · 1.26 KB
/
main.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
#include <stdio.h> // printf
#include <string.h> // strcmp
#include "splines.h"
#define STEP 0.1
point in_points[] = {{-8.0, 7.0}, {-5.0, 2.0}, {0.0, 5.0}, {4.0, -4.0}, {7.0, 0.0}};
const size_t n_in_points = sizeof(in_points) / sizeof(point);
int main(int argc, char *argv[])
{
if(argc == 1)
{
printf("A print parameter has been missed. (akima, cubic, points)\n");
return 0;
}
int result = -1;
size_t n_out_points = 0;
point* out_points = NULL;
if(strcmp(argv[1], "akima") == 0)
{
result = akima_spline(in_points, n_in_points, STEP, &out_points, &n_out_points);
}
else if(strcmp(argv[1], "cubic") == 0)
{
result = cubic_spline(in_points, n_in_points, STEP, &out_points, &n_out_points);
}
else if(strcmp(argv[1], "points") == 0)
{
result = 0;
out_points = in_points;
n_out_points = n_in_points;
}
else
{
printf("A print parameter isn't recognized. (akima, cubic, points)\n");
}
if(result == 0)
{
//printf("%s\n", argv[1]);
for(size_t i = 0; i < n_out_points; ++i)
{
printf("%f,%f\n", out_points[i].x, out_points[i].y);
}
}
if(!out_points)
free(out_points);
return 0;
}