File: entropy.c

package info (click to toggle)
radare2 0.9.6-3.1%2Bdeb8u1
  • links: PTS, VCS
  • area: main
  • in suites: jessie
  • size: 17,496 kB
  • ctags: 45,959
  • sloc: ansic: 240,999; sh: 3,645; makefile: 2,520; python: 1,212; asm: 312; ruby: 214; awk: 209; perl: 188; lisp: 169; java: 23; xml: 17; php: 6
file content (55 lines) | stat: -rw-r--r-- 1,412 bytes parent folder | download | duplicates (3)
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
/*
 * This code was done 
 *    by an anonymous gnome
 * ------------------------
 * That's pure mathematics, so no sense to adding license shit here.
 */

#include <stdlib.h>
#include <math.h>
#include "r_types.h"

static double get_px(ut8 x, const ut8 *data, ut64 size) {
        ut64 i, count = 0;
        for (i = 0; i < size; i++)
                if (data[i] == x)
                        count++;
        return (double) count / size;
}

R_API double r_hash_entropy(const ut8 *data, ut64 size) {
        ut32 x;
        double h = 0, px, log2 = log (2.0);
        for (x = 0; x < 256; x++) {
                px = get_px (x, data, size);
                if (px > 0)
                        h += -px * (log (px) / log2);
        }
        return h;
}

R_API double r_hash_entropy_fraction(const ut8 *data, ut64 size) {
	double h = r_hash_entropy (data, size);
	if (size < 256)
		return h * log (2.0) / log (size);
	return h/8; //(size/256);//8;
}

// 0-8
#if TEST
main() {
	int i;
	ut8 b[40960];
	for (i=0;i<sizeof(b);i++)
		b[i] = i;
	//memset (b, 'A', sizeof (b));
	memset (b, 'A', 512);
	printf ("%f\n", r_hash_entropy (b, 10));
	printf ("%f\n", r_hash_entropy (b, 100));
	printf ("%f\n", r_hash_entropy (b, 200));
	printf ("%f\n", r_hash_entropy (b, 256));
	printf ("%f\n", r_hash_entropy (b, 4095));
	printf ("%f\n", r_hash_entropy (b, 8095));
	printf ("%f\n", r_hash_entropy (b, sizeof (b)));
}
#endif