image.h 2.4 KB
Newer Older
Z
zhangyang 已提交
1 2 3 4 5 6 7 8 9 10 11 12
/* Copyright (c) 2018 PaddlePaddle Authors. All Rights Reserved.

Licensed under the Apache License, Version 2.0 (the "License");
you may not use this file except in compliance with the License.
You may obtain a copy of the License at

    http://www.apache.org/licenses/LICENSE-2.0

Unless required by applicable law or agreed to in writing, software
distributed under the License is distributed on an "AS IS" BASIS,
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
See the License for the specific language governing permissions and
Z
zhangyang 已提交
13
limitations under the License. */
Z
zhangyang 已提交
14 15

#pragma once
Z
zhangyang 已提交
16

17 18 19 20
#include <memory.h>
#include <algorithm>
#include <cstdint>
#include "fpga/common/fpga_common.h"
Z
zhangyang 已提交
21 22 23 24
namespace paddle_mobile {
namespace fpga {
namespace image {

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
void convert_to_hwc(float** data_in, int channel, int height, int width,
                    int num = 1);
void convert_to_chw(float** data_in, int channel, int height, int width,
                    int num = 1);
template <typename Dtype>
void align_element_conv(Dtype** data_in, int height, int cw);
template <typename Dtype>
void align_element_conv(Dtype** data_in, int height, int cw) {
  int h = 0;
  int align_cw = align_to_x(cw, IMAGE_ALIGNMENT);

  Dtype* data_tmp =
      (Dtype*)fpga_malloc(height * align_cw * sizeof(Dtype));  // NOLINT

  memset(data_tmp, 0, height * align_cw * sizeof(Dtype));

  for (h = 0; h < height; h++) {
    memcpy((void*)(data_tmp + h * align_cw),  // NOLINT
           (void*)(*data_in + h * cw),        // NOLINT
           cw * sizeof(Dtype));
  }

  *data_in = data_tmp;
}
template <typename T>
void format_image(T** data_in, int channel, int height, int width) {
  int cw = channel * width;
  int align_cw = align_to_x(cw, IMAGE_ALIGNMENT);
  if (align_cw != cw) {
    T* hwc_temp = *data_in;
    align_element_conv(data_in, height, channel * width);
    fpga_free(hwc_temp);
  }
  fpga_flush(*data_in,
             align_to_x(channel * width, IMAGE_ALIGNMENT) * height * sizeof(T));
}
// Concat featuremaps along channel direction
62
void concat_images(int8_t** images_in, float** scales_in, void* image_out,
63 64
                   float* scale_out, int image_num, uint32_t* channel_num,
                   int height, int width);
Z
zhangyang 已提交
65

66
// Split featuremap along channel direction
67
void split_image(int8_t* image_in, void** images_out, int image_num,
68
                 const uint32_t* channel_nums, int height, int width);
Z
zhangyang 已提交
69 70 71
}  // namespace image
}  // namespace fpga
}  // namespace paddle_mobile