Blame src/utils/quant_levels_utils.h

Packit 9c6abc
// Copyright 2011 Google Inc. All Rights Reserved.
Packit 9c6abc
//
Packit 9c6abc
// Use of this source code is governed by a BSD-style license
Packit 9c6abc
// that can be found in the COPYING file in the root of the source
Packit 9c6abc
// tree. An additional intellectual property rights grant can be found
Packit 9c6abc
// in the file PATENTS. All contributing project authors may
Packit 9c6abc
// be found in the AUTHORS file in the root of the source tree.
Packit 9c6abc
// -----------------------------------------------------------------------------
Packit 9c6abc
//
Packit 9c6abc
// Alpha plane quantization utility
Packit 9c6abc
//
Packit 9c6abc
// Author:  Vikas Arora (vikasa@google.com)
Packit 9c6abc
Packit 9c6abc
#ifndef WEBP_UTILS_QUANT_LEVELS_UTILS_H_
Packit 9c6abc
#define WEBP_UTILS_QUANT_LEVELS_UTILS_H_
Packit 9c6abc
Packit 9c6abc
#include <stdlib.h>
Packit 9c6abc
Packit 9c6abc
#include "src/webp/types.h"
Packit 9c6abc
Packit 9c6abc
#ifdef __cplusplus
Packit 9c6abc
extern "C" {
Packit 9c6abc
#endif
Packit 9c6abc
Packit 9c6abc
// Replace the input 'data' of size 'width'x'height' with 'num-levels'
Packit 9c6abc
// quantized values. If not NULL, 'sse' will contain the sum of squared error.
Packit 9c6abc
// Valid range for 'num_levels' is [2, 256].
Packit 9c6abc
// Returns false in case of error (data is NULL, or parameters are invalid).
Packit 9c6abc
int QuantizeLevels(uint8_t* const data, int width, int height, int num_levels,
Packit 9c6abc
                   uint64_t* const sse);
Packit 9c6abc
Packit 9c6abc
#ifdef __cplusplus
Packit 9c6abc
}    // extern "C"
Packit 9c6abc
#endif
Packit 9c6abc
Packit 9c6abc
#endif  /* WEBP_UTILS_QUANT_LEVELS_UTILS_H_ */