-
Notifications
You must be signed in to change notification settings - Fork 5
/
Copy pathsmrdist.c
executable file
·78 lines (65 loc) · 1.97 KB
/
smrdist.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
65
66
67
68
69
70
71
72
73
74
75
76
77
/*
* SMR distance algorithm
*
* Aysegul Dundar 2014
*/
#include <luaT.h>
#include <TH/TH.h>
#include <math.h>
#include <stdio.h>
#include <stdlib.h>
#define abs(a) (a) < 0 ? -(a) : (a)
static int dist_smr(lua_State * L)
{
// get args
const void* torch_FloatTensor_id = luaT_checktypename2id(L, "torch.FloatTensor");
THFloatTensor *output_ptr = luaT_checkudata(L, 1, torch_FloatTensor_id);
THFloatTensor *input_ptr = luaT_checkudata(L, 2, torch_FloatTensor_id);
THFloatTensor *kernel_ptr = luaT_checkudata(L, 3, torch_FloatTensor_id);
float dynamic = lua_tonumber(L, 4);
int begin_x = lua_tonumber(L, 5);
int end_x = lua_tonumber(L, 6);
int begin_y = lua_tonumber(L, 7);
int end_y = lua_tonumber(L, 8);
// get raw pointers
float *output = THFloatTensor_data(output_ptr);
float *input = THFloatTensor_data(input_ptr);
float *kernel = THFloatTensor_data(kernel_ptr);
// dims
int kheight = kernel_ptr->size[0];
int kwidth = kernel_ptr->size[1];
//strides
long *is = input_ptr->stride;
long *ks = kernel_ptr->stride;
long *os = output_ptr->stride;
// similarity matching ratio (SMR)
int i, j, x, y, pos;
float probability;
float distance;
for(y = begin_y; y < end_y; y++) {
for(x = begin_x; x < end_x; x++) {
pos = y*is[0]+x*is[1];
probability = 0;
for(j=0; j< kheight; j++) {
for(i=0; i< kwidth; i++) {
distance = abs(input[ pos+j*is[0]+i*is[1] ]- kernel[ j*ks[0]+i*ks[1] ]);
if (distance<dynamic/2)
probability = probability + exp(-2*distance);
}
}
output[y*os[0]+x*os[1]] = probability;
}
}
lua_newtable(L); // result = {}
int result = lua_gettop(L);
return 0;
}
static const struct luaL_reg smrdist[] = {
{"smr", dist_smr},
{NULL, NULL}
};
int luaopen_libsmrdist(lua_State * L)
{
luaL_register(L, "libsmrdist", smrdist);
return 1;
}