cpu.c 3.14 KB
Newer Older
rusty1s's avatar
rusty1s committed
1
#ifndef TH_GENERIC_FILE
rusty1s's avatar
rusty1s committed
2
#define TH_GENERIC_FILE "generic/cpu.c"
rusty1s's avatar
rusty1s committed
3
4
#else

rusty1s's avatar
rusty1s committed
5
void scatter_(mul)(int dim, THTensor *output, THLongTensor *index, THTensor *input) {
rusty1s's avatar
rusty1s committed
6
  int64_t i, idx;
rusty1s's avatar
rusty1s committed
7
  TH_TENSOR_DIM_APPLY3(real, output, int64_t, index, real, input, dim, TH_TENSOR_DIM_APPLY3_SIZE_EQ_EXCEPT_DIM,
rusty1s's avatar
c99 c  
rusty1s committed
8
    for (i = 0; i < THLongTensor_size(index, dim); i++) {
rusty1s's avatar
rusty1s committed
9
10
11
      idx = *(index_data + i * index_stride);
      assertIndexInBoundaries(idx, output_size, TH_TENSOR_DIM_APPLY_counter);
      output_data[idx * output_stride] *= *(input_data + i * input_stride);
rusty1s's avatar
rusty1s committed
12
13
14
    })
}

rusty1s's avatar
rusty1s committed
15
void scatter_(div)(int dim, THTensor *output, THLongTensor *index, THTensor *input) {
rusty1s's avatar
rusty1s committed
16
  int64_t i, idx;
rusty1s's avatar
rusty1s committed
17
  TH_TENSOR_DIM_APPLY3(real, output, int64_t, index, real, input, dim, TH_TENSOR_DIM_APPLY3_SIZE_EQ_EXCEPT_DIM,
rusty1s's avatar
c99 c  
rusty1s committed
18
    for (i = 0; i < THLongTensor_size(index, dim); i++) {
rusty1s's avatar
rusty1s committed
19
20
21
      idx = *(index_data + i * index_stride);
      assertIndexInBoundaries(idx, output_size, TH_TENSOR_DIM_APPLY_counter);
      output_data[idx * output_stride] /= *(input_data + i * input_stride);
rusty1s's avatar
rusty1s committed
22
23
24
    })
}

rusty1s's avatar
rusty1s committed
25
void scatter_(mean)(int dim, THTensor *output, THLongTensor *index, THTensor *input, THTensor *count) {
rusty1s's avatar
rusty1s committed
26
  int64_t i, idx;
rusty1s's avatar
rusty1s committed
27
  TH_TENSOR_DIM_APPLY4(real, output, int64_t, index, real, input, real, count, dim,
rusty1s's avatar
c99 c  
rusty1s committed
28
    for (i = 0; i < THLongTensor_size(index, dim); i++) {
rusty1s's avatar
rusty1s committed
29
30
      idx = *(index_data + i * index_stride);
      assertIndexInBoundaries(idx, output_size, TH_TENSOR_DIM_APPLY_counter);
rusty1s's avatar
rusty1s committed
31
      output_data[idx * output_stride] += *(input_data + i * input_stride);
rusty1s's avatar
rusty1s committed
32
      count_data[idx * count_stride]++;
rusty1s's avatar
rusty1s committed
33
34
35
    })
}

rusty1s's avatar
rusty1s committed
36
void scatter_(max)(int dim, THTensor *output, THLongTensor *index, THTensor *input, THLongTensor *arg) {
rusty1s's avatar
rusty1s committed
37
  int64_t i, idx;
rusty1s's avatar
rusty1s committed
38
  TH_TENSOR_DIM_APPLY4(real, output, int64_t, index, real, input, int64_t, arg, dim,
rusty1s's avatar
c99 c  
rusty1s committed
39
    for (i = 0; i < THLongTensor_size(index, dim); i++) {
rusty1s's avatar
rusty1s committed
40
41
42
43
44
      idx = *(index_data + i * index_stride);
      assertIndexInBoundaries(idx, output_size, TH_TENSOR_DIM_APPLY_counter);
      if (*(input_data + i * input_stride) >= *(output_data + idx * output_stride)) {
        output_data[idx * output_stride] = *(input_data + i * input_stride);
        arg_data[idx * arg_stride] = i;
rusty1s's avatar
rusty1s committed
45
      }
rusty1s's avatar
min max  
rusty1s committed
46
47
48
    })
}

rusty1s's avatar
rusty1s committed
49
void scatter_(min)(int dim, THTensor *output, THLongTensor *index, THTensor *input, THLongTensor *arg) {
rusty1s's avatar
rusty1s committed
50
  int64_t i, idx;
rusty1s's avatar
rusty1s committed
51
  TH_TENSOR_DIM_APPLY4(real, output, int64_t, index, real, input, int64_t, arg, dim,
rusty1s's avatar
c99 c  
rusty1s committed
52
    for (i = 0; i < THLongTensor_size(index, dim); i++) {
rusty1s's avatar
rusty1s committed
53
54
55
56
57
      idx = *(index_data + i * index_stride);
      assertIndexInBoundaries(idx, output_size, TH_TENSOR_DIM_APPLY_counter);
      if (*(input_data + i * input_stride) <= *(output_data + idx * output_stride)) {
        output_data[idx * output_stride] = *(input_data + i * input_stride);
        arg_data[idx * arg_stride] = i;
rusty1s's avatar
rusty1s committed
58
59
60
61
      }
    })
}

rusty1s's avatar
rusty1s committed
62
void index_backward(int dim, THTensor *output, THLongTensor *index, THTensor *grad, THLongTensor *arg) {
rusty1s's avatar
rusty1s committed
63
  int64_t i, idx;
rusty1s's avatar
rusty1s committed
64
  TH_TENSOR_DIM_APPLY4(real, output, int64_t, index, real, grad, int64_t, arg, dim,
rusty1s's avatar
c99 c  
rusty1s committed
65
    for (i = 0; i < THLongTensor_size(index, dim); i++) {
rusty1s's avatar
rusty1s committed
66
67
      idx = *(index_data + i * index_stride);
      if (*(arg_data + idx * arg_stride) == i) output_data[i * output_stride] = *(grad_data + idx * grad_stride);
rusty1s's avatar
min max  
rusty1s committed
68
69
70
    })
}

rusty1s's avatar
rusty1s committed
71
#endif