cpu.c 548 Bytes
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
5
#else

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

#endif