1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
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
|
// Copyright 2023 Intel Corporation.
//
// This software and the related documents are Intel copyrighted materials,
// and your use of them is governed by the express license under which they
// were provided to you ("License"). Unless the License provides otherwise,
// you may not use, modify, copy, publish, distribute, disclose or transmit
// this software or the related documents without Intel's prior written
// permission.
//
// This software and the related documents are provided as is, with no express
// or implied warranties, other than those that are expressly stated in the
// License.
#pragma once
#include <cstdint>
#include <filesystem>
#include <memory>
#include <vector>
#include "ILayoutTransform.h"
#include "bmp_file.h"
#include "float16.h"
class RawImage {
public:
RawImage(std::filesystem::path filePath,
bool runLayoutTransform,
const ILayoutTransform::Configuration& ltConfiguration);
uint8_t* GetData();
size_t GetSize();
std::string Filename() { return _filePath; }
bool DumpLayoutTransform();
static std::vector<uint16_t> LayoutTransform(uint32_t width,
uint32_t height,
const std::vector<uint8_t>& data,
const ILayoutTransform::Configuration& ltConfiguration);
static std::vector<uint8_t> MakePlanar(uint32_t width, uint32_t height, const std::vector<uint8_t>& data);
bool IsValid();
private:
static void GenerateLayoutIndexes(const ILayoutTransform::Configuration& ltConfiguration);
void LayoutTransform(const ILayoutTransform::Configuration& ltConfiguration);
static std::vector<uint16_t> LayoutTransform(const std::vector<uint8_t>& sourceData,
uint32_t numPixels,
const ILayoutTransform::Configuration& ltConfiguration);
std::filesystem::path _filePath;
std::shared_ptr<BmpFile> _spBmpFile;
std::vector<uint16_t> _layoutTransformData;
static std::vector<int32_t> _indexes;
bool _runLayoutTransform = false;
ILayoutTransform::Configuration _ltConfiguration;
};
|