main.c 2.3 KB
Newer Older
Y
Yu Yang 已提交
1 2
#include <paddle/capi.h>
#include <time.h>
P
peterzhang2029 已提交
3

Y
Yu Yang 已提交
4 5 6 7 8 9
#include "../common/common.h"

#define CONFIG_BIN "./trainer_config.bin"

int main() {
  // Initalize Paddle
P
peterzhang2029 已提交
10 11
  char* argv[] = {"--use_gpu=False"};
  CHECK(paddle_init(1, (char**)argv));
Y
Yu Yang 已提交
12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30

  // Reading config binary file. It is generated by `convert_protobin.sh`
  long size;
  void* buf = read_config(CONFIG_BIN, &size);

  // Create a gradient machine for inference.
  paddle_gradient_machine machine;
  CHECK(paddle_gradient_machine_create_for_inference(&machine, buf, (int)size));
  CHECK(paddle_gradient_machine_randomize_param(machine));

  // Loading parameter. Uncomment the following line and change the directory.
  // CHECK(paddle_gradient_machine_load_parameter_from_disk(machine,
  //                                                "./some_where_to_params"));
  paddle_arguments in_args = paddle_arguments_create_none();

  // There is only one input of this network.
  CHECK(paddle_arguments_resize(in_args, 1));

  // Create input matrix.
P
peterzhang2029 已提交
31
  paddle_matrix mat = paddle_matrix_create(/* sample_num */ 1,
Y
Yu Yang 已提交
32 33 34 35
                                           /* size */ 784,
                                           /* useGPU */ false);
  srand(time(0));

P
peterzhang2029 已提交
36
  paddle_real* array;
Y
Yu Yang 已提交
37

P
peterzhang2029 已提交
38 39
  // Get First row.
  CHECK(paddle_matrix_get_row(mat, 0, &array));
P
peterzhang2029 已提交
40

P
peterzhang2029 已提交
41 42 43
  for (int i = 0; i < 784; ++i) {
    array[i] = rand() / ((float)RAND_MAX);
  }
Y
Yu Yang 已提交
44 45 46 47 48 49 50 51 52 53

  CHECK(paddle_arguments_set_value(in_args, 0, mat));

  paddle_arguments out_args = paddle_arguments_create_none();
  CHECK(paddle_gradient_machine_forward(machine,
                                        in_args,
                                        out_args,
                                        /* isTrain */ false));
  paddle_matrix prob = paddle_matrix_create_none();

Y
Yu Yang 已提交
54
  CHECK(paddle_arguments_get_value(out_args, 0, prob));
Y
Yu Yang 已提交
55

P
peterzhang2029 已提交
56 57
  uint64_t height;
  uint64_t width;
58

P
peterzhang2029 已提交
59
  CHECK(paddle_matrix_get_shape(prob, &height, &width));
P
peterzhang2029 已提交
60
  CHECK(paddle_matrix_get_row(prob, 0, &array));
Y
Yu Yang 已提交
61

P
peterzhang2029 已提交
62
  printf("Prob: \n");
63
  for (int i = 0; i < height * width; ++i) {
P
peterzhang2029 已提交
64
    printf("%.4f ", array[i]);
P
peterzhang2029 已提交
65
    if ((i + 1) % width == 0) {
P
peterzhang2029 已提交
66 67
      printf("\n");
    }
Y
Yu Yang 已提交
68 69 70
  }
  printf("\n");

Y
Yu Yang 已提交
71 72 73 74 75 76
  CHECK(paddle_matrix_destroy(prob));
  CHECK(paddle_arguments_destroy(out_args));
  CHECK(paddle_matrix_destroy(mat));
  CHECK(paddle_arguments_destroy(in_args));
  CHECK(paddle_gradient_machine_destroy(machine));

Y
Yu Yang 已提交
77 78
  return 0;
}