blob: 1cb5a32caea6ee45a113565e74474e8a67dc25c6 [file] [log] [blame]
Vikas Aroraa2415722012-08-09 16:18:58 -07001// Copyright 2011 Google Inc. All Rights Reserved.
2//
Vikas Arora0406ce12013-08-09 15:57:12 -07003// Use of this source code is governed by a BSD-style license
4// that can be found in the COPYING file in the root of the source
5// tree. An additional intellectual property rights grant can be found
6// in the file PATENTS. All contributing project authors may
7// be found in the AUTHORS file in the root of the source tree.
Vikas Aroraa2415722012-08-09 16:18:58 -07008// -----------------------------------------------------------------------------
9//
10// Alpha plane quantization utility
11//
12// Author: Vikas Arora (vikasa@google.com)
13
14#ifndef WEBP_UTILS_QUANT_LEVELS_H_
15#define WEBP_UTILS_QUANT_LEVELS_H_
16
17#include <stdlib.h>
18
James Zern9e80ee92015-03-17 18:54:21 -070019#include "../webp/types.h"
Vikas Aroraa2415722012-08-09 16:18:58 -070020
Vikas Arora8b720222014-01-02 16:48:02 -080021#ifdef __cplusplus
Vikas Aroraa2415722012-08-09 16:18:58 -070022extern "C" {
23#endif
24
25// Replace the input 'data' of size 'width'x'height' with 'num-levels'
26// quantized values. If not NULL, 'sse' will contain the sum of squared error.
27// Valid range for 'num_levels' is [2, 256].
28// Returns false in case of error (data is NULL, or parameters are invalid).
29int QuantizeLevels(uint8_t* const data, int width, int height, int num_levels,
30 uint64_t* const sse);
31
Vikas Arora8b720222014-01-02 16:48:02 -080032#ifdef __cplusplus
Vikas Aroraa2415722012-08-09 16:18:58 -070033} // extern "C"
34#endif
35
36#endif /* WEBP_UTILS_QUANT_LEVELS_H_ */