| Index: media/video/half_float_maker.h
|
| diff --git a/media/video/half_float_maker.h b/media/video/half_float_maker.h
|
| new file mode 100644
|
| index 0000000000000000000000000000000000000000..06ae2abc47f417df53b8c6464475b558cd405249
|
| --- /dev/null
|
| +++ b/media/video/half_float_maker.h
|
| @@ -0,0 +1,32 @@
|
| +// Copyright 2017 The Chromium Authors. All rights reserved.
|
| +// Use of this source code is governed by a BSD-style license that can be
|
| +// found in the LICENSE file.
|
| +
|
| +#ifndef MEDIA_VIDEO_HALF_FLOAT_MAKER_H_
|
| +#define MEDIA_VIDEO_HALF_FLOAT_MAKER_H_
|
| +
|
| +#include <stddef.h>
|
| +#include <stdint.h>
|
| +
|
| +namespace media {
|
| +
|
| +class HalfFloatMaker {
|
| + public:
|
| + // Convert an array of short integers into an array of half-floats.
|
| + // |src| is an array of integers in range 0 .. 2^{bits_per_channel} - 1
|
| + // |num| is number of entries in input and output array.
|
| + // The numbers stored in |dst| will be half floats in range 0.0..1.0
|
| + virtual void MakeHalfFloats(const uint16_t* src,
|
| + size_t num,
|
| + uint16_t* dst) = 0;
|
| + // The half-floats made needs by this class will be in the range
|
| + // [Offset() .. Offset() + 1.0/Multiplier]. So if you want results
|
| + // in the 0-1 range, you need to do:
|
| + // (half_float - Offset()) * Multiplier()
|
| + // to each returned value.
|
| + virtual float Offset() const = 0;
|
| + virtual float Multiplier() const = 0;
|
| +};
|
| +
|
| +} // namespace media
|
| +#endif // MEDIA_VIDEO_HALF_FLOAT_MAKER_H_
|
|
|