decode_image.cpp 1.22 KB
Newer Older
1
#include "decode_image.h"
2

3
4
5
6
7
#include "decode_jpeg.h"
#include "decode_png.h"

namespace vision {
namespace image {
Francisco Massa's avatar
Francisco Massa committed
8

9
10
11
12
torch::Tensor decode_image(
    const torch::Tensor& data,
    ImageReadMode mode,
    bool apply_exif_orientation) {
13
14
  // Check that tensor is a CPU tensor
  TORCH_CHECK(data.device() == torch::kCPU, "Expected a CPU tensor");
Francisco Massa's avatar
Francisco Massa committed
15
16
17
18
19
20
21
22
23
24
25
26
27
  // Check that the input tensor dtype is uint8
  TORCH_CHECK(data.dtype() == torch::kU8, "Expected a torch.uint8 tensor");
  // Check that the input tensor is 1-dimensional
  TORCH_CHECK(
      data.dim() == 1 && data.numel() > 0,
      "Expected a non empty 1-dimensional tensor");

  auto datap = data.data_ptr<uint8_t>();

  const uint8_t jpeg_signature[3] = {255, 216, 255}; // == "\xFF\xD8\xFF"
  const uint8_t png_signature[4] = {137, 80, 78, 71}; // == "\211PNG"

  if (memcmp(jpeg_signature, datap, 3) == 0) {
28
    return decode_jpeg(data, mode, apply_exif_orientation);
Francisco Massa's avatar
Francisco Massa committed
29
  } else if (memcmp(png_signature, datap, 4) == 0) {
30
31
    return decode_png(
        data, mode, /*allow_16_bits=*/false, apply_exif_orientation);
Francisco Massa's avatar
Francisco Massa committed
32
33
34
35
36
37
38
  } else {
    TORCH_CHECK(
        false,
        "Unsupported image file. Only jpeg and png ",
        "are currently supported.");
  }
}
39
40
41

} // namespace image
} // namespace vision