-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathmain.c
More file actions
84 lines (79 loc) · 2.62 KB
/
main.c
File metadata and controls
84 lines (79 loc) · 2.62 KB
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
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
#include <stdio.h>
#include <assert.h>
#include <math.h>
#include "roc.h"
double roc_brute(const int* actual, const double* pred, size_t n) {
double num = 0;
int denum = 0;
int i, j;
for (i = 0; i < n; i++) {
for (j = 0; j < n; j++) {
int f = actual[i] < actual[j];
double g = EPS_EQUAL(pred[i], pred[j]) ? 0.5 : (pred[i] < pred[j] ? 1.0 : 0.0);
num += f * g;
denum += f;
}
}
return num / denum;
}
void run_test(const int* label, const int* actual, const double* pred, size_t n, double expected) {
double res = mean_roc_auc(label, actual, pred, n);
if (fabs(res - expected) > 1e-8) {
int i;
printf("Assert failed\nActual:");
for (i = 0; i < n; i++) {
printf("\t%d", actual[i]);
}
printf("\n");
printf("Pred:");
for (i = 0; i < n; i++) {
printf("\t%f", pred[i]);
}
printf("\n");
printf("EXPECTED %f TO EQUAL %f\n", res, expected);
printf("\n");
}
}
void run_tests() {
{
int label[] = {0, 0, 0, 0};
int actual[] = {0, 1, 1, 0};
double pred[] = {0.1, 0.2, 0.3, 0.4};
run_test(label, actual, pred, sizeof(actual) / sizeof(actual[0]), 0.5);
}
{
int label[] = {0, 0, 0};
int actual[] = {0, 1, 1};
double pred[] = {0.0, 0.1, 0.1};
run_test(label, actual, pred, sizeof(actual) / sizeof(actual[0]), 1.0);
}
{
int label[] = {0, 0, 0, 0, 0};
int actual[] = {0, 1, 0, 1, 0};
double pred[] = {0.1, 0.1, 0.0, -0.4, 0.7};
run_test(label, actual, pred, sizeof(actual) / sizeof(actual[0]), 0.25);
}
{
int label[] = {0, 0, 0, 0, 0, 0};
int actual[] = {0, 1, 0, 1, 1, 1};
double pred[] = {0.1, 0.5, 0.1, 0.2, 0.2, -7};
run_test(label, actual, pred, sizeof(actual) / sizeof(actual[0]), 0.75);
}
{
int label[] = {0, 0, 0, 0, 0, 0, 0};
int actual[] = {0, 0, 0, 0, 0, 1, 0};
double pred[] = {1.20648799e-30, 1.48942199e-01, 5.61005734e-01, 0.00000000e+00,
5.84090818e-01, 0.00000000e+00, 3.83774804e-01};
run_test(label, actual, pred, sizeof(actual) / sizeof(actual[0]), 0.08333333333333331);
}
{
int label[] = {7, 7, 13, 19, 7, 16, 1, 13, 13, 13, 13, 13, 1, 13, 1};
int actual[] = {1, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0};
double pred[] = {1., 0., 0., 0., 1., 0., 0., 0., 0., 0., 0., 0., 0., 0., 0.};
run_test(label, actual, pred, sizeof(actual) / sizeof(actual[0]), 1.0);
}
}
int main() {
run_tests();
return 0;
}