2013-01-18 11:51:12 -08:00
|
|
|
/*
|
|
|
|
* Copyright (c) 2013 The WebM project authors. All Rights Reserved.
|
|
|
|
*
|
|
|
|
* Use of this source code is governed by a BSD-style license
|
|
|
|
* that can be found in the LICENSE file in the root of the source
|
|
|
|
* tree. An additional intellectual property rights grant can be found
|
|
|
|
* in the file PATENTS. All contributing project authors may
|
|
|
|
* be found in the AUTHORS file in the root of the source tree.
|
|
|
|
*/
|
|
|
|
#ifndef TEST_CODEC_FACTORY_H_
|
|
|
|
#define TEST_CODEC_FACTORY_H_
|
|
|
|
|
|
|
|
#include "./vpx_config.h"
|
|
|
|
#include "vpx/vpx_decoder.h"
|
|
|
|
#include "vpx/vpx_encoder.h"
|
|
|
|
#if CONFIG_VP8_ENCODER || CONFIG_VP9_ENCODER
|
|
|
|
#include "vpx/vp8cx.h"
|
|
|
|
#endif
|
|
|
|
#if CONFIG_VP8_DECODER || CONFIG_VP9_DECODER
|
|
|
|
#include "vpx/vp8dx.h"
|
|
|
|
#endif
|
|
|
|
|
|
|
|
#include "test/decode_test_driver.h"
|
|
|
|
#include "test/encode_test_driver.h"
|
|
|
|
namespace libvpx_test {
|
|
|
|
|
2014-02-06 17:13:08 -08:00
|
|
|
const int kCodecFactoryParam = 0;
|
|
|
|
|
2013-01-18 11:51:12 -08:00
|
|
|
class CodecFactory {
|
|
|
|
public:
|
|
|
|
CodecFactory() {}
|
|
|
|
|
|
|
|
virtual ~CodecFactory() {}
|
|
|
|
|
|
|
|
virtual Decoder* CreateDecoder(vpx_codec_dec_cfg_t cfg,
|
|
|
|
unsigned long deadline) const = 0;
|
|
|
|
|
|
|
|
virtual Encoder* CreateEncoder(vpx_codec_enc_cfg_t cfg,
|
|
|
|
unsigned long deadline,
|
|
|
|
const unsigned long init_flags,
|
|
|
|
TwopassStatsStore *stats) const = 0;
|
|
|
|
|
|
|
|
virtual vpx_codec_err_t DefaultEncoderConfig(vpx_codec_enc_cfg_t *cfg,
|
|
|
|
int usage) const = 0;
|
|
|
|
};
|
|
|
|
|
|
|
|
/* Provide CodecTestWith<n>Params classes for a variable number of parameters
|
|
|
|
* to avoid having to include a pointer to the CodecFactory in every test
|
|
|
|
* definition.
|
|
|
|
*/
|
|
|
|
template<class T1>
|
|
|
|
class CodecTestWithParam : public ::testing::TestWithParam<
|
|
|
|
std::tr1::tuple< const libvpx_test::CodecFactory*, T1 > > {
|
|
|
|
};
|
|
|
|
|
|
|
|
template<class T1, class T2>
|
|
|
|
class CodecTestWith2Params : public ::testing::TestWithParam<
|
|
|
|
std::tr1::tuple< const libvpx_test::CodecFactory*, T1, T2 > > {
|
|
|
|
};
|
|
|
|
|
|
|
|
template<class T1, class T2, class T3>
|
|
|
|
class CodecTestWith3Params : public ::testing::TestWithParam<
|
|
|
|
std::tr1::tuple< const libvpx_test::CodecFactory*, T1, T2, T3 > > {
|
|
|
|
};
|
|
|
|
|
|
|
|
/*
|
|
|
|
* VP8 Codec Definitions
|
|
|
|
*/
|
|
|
|
#if CONFIG_VP8
|
|
|
|
class VP8Decoder : public Decoder {
|
|
|
|
public:
|
|
|
|
VP8Decoder(vpx_codec_dec_cfg_t cfg, unsigned long deadline)
|
|
|
|
: Decoder(cfg, deadline) {}
|
|
|
|
|
|
|
|
protected:
|
2014-01-31 16:32:42 -08:00
|
|
|
virtual vpx_codec_iface_t* CodecInterface() const {
|
2013-01-18 11:51:12 -08:00
|
|
|
#if CONFIG_VP8_DECODER
|
|
|
|
return &vpx_codec_vp8_dx_algo;
|
|
|
|
#else
|
|
|
|
return NULL;
|
|
|
|
#endif
|
|
|
|
}
|
|
|
|
};
|
|
|
|
|
|
|
|
class VP8Encoder : public Encoder {
|
|
|
|
public:
|
|
|
|
VP8Encoder(vpx_codec_enc_cfg_t cfg, unsigned long deadline,
|
|
|
|
const unsigned long init_flags, TwopassStatsStore *stats)
|
|
|
|
: Encoder(cfg, deadline, init_flags, stats) {}
|
|
|
|
|
|
|
|
protected:
|
2014-01-31 16:32:42 -08:00
|
|
|
virtual vpx_codec_iface_t* CodecInterface() const {
|
2013-01-18 11:51:12 -08:00
|
|
|
#if CONFIG_VP8_ENCODER
|
|
|
|
return &vpx_codec_vp8_cx_algo;
|
|
|
|
#else
|
|
|
|
return NULL;
|
|
|
|
#endif
|
|
|
|
}
|
|
|
|
};
|
|
|
|
|
|
|
|
class VP8CodecFactory : public CodecFactory {
|
|
|
|
public:
|
|
|
|
VP8CodecFactory() : CodecFactory() {}
|
|
|
|
|
|
|
|
virtual Decoder* CreateDecoder(vpx_codec_dec_cfg_t cfg,
|
|
|
|
unsigned long deadline) const {
|
|
|
|
#if CONFIG_VP8_DECODER
|
|
|
|
return new VP8Decoder(cfg, deadline);
|
|
|
|
#else
|
|
|
|
return NULL;
|
|
|
|
#endif
|
|
|
|
}
|
|
|
|
|
|
|
|
virtual Encoder* CreateEncoder(vpx_codec_enc_cfg_t cfg,
|
|
|
|
unsigned long deadline,
|
|
|
|
const unsigned long init_flags,
|
|
|
|
TwopassStatsStore *stats) const {
|
|
|
|
#if CONFIG_VP8_ENCODER
|
|
|
|
return new VP8Encoder(cfg, deadline, init_flags, stats);
|
|
|
|
#else
|
|
|
|
return NULL;
|
|
|
|
#endif
|
|
|
|
}
|
|
|
|
|
|
|
|
virtual vpx_codec_err_t DefaultEncoderConfig(vpx_codec_enc_cfg_t *cfg,
|
|
|
|
int usage) const {
|
|
|
|
#if CONFIG_VP8_ENCODER
|
|
|
|
return vpx_codec_enc_config_default(&vpx_codec_vp8_cx_algo, cfg, usage);
|
|
|
|
#else
|
|
|
|
return VPX_CODEC_INCAPABLE;
|
|
|
|
#endif
|
|
|
|
}
|
|
|
|
};
|
|
|
|
|
|
|
|
const libvpx_test::VP8CodecFactory kVP8;
|
|
|
|
|
2013-07-02 14:14:16 -07:00
|
|
|
#define VP8_INSTANTIATE_TEST_CASE(test, ...)\
|
2013-01-18 11:51:12 -08:00
|
|
|
INSTANTIATE_TEST_CASE_P(VP8, test, \
|
|
|
|
::testing::Combine( \
|
|
|
|
::testing::Values(static_cast<const libvpx_test::CodecFactory*>( \
|
|
|
|
&libvpx_test::kVP8)), \
|
2013-07-02 14:14:16 -07:00
|
|
|
__VA_ARGS__))
|
2013-01-18 11:51:12 -08:00
|
|
|
#else
|
2013-07-02 14:14:16 -07:00
|
|
|
#define VP8_INSTANTIATE_TEST_CASE(test, ...)
|
2013-01-18 11:51:12 -08:00
|
|
|
#endif // CONFIG_VP8
|
|
|
|
|
|
|
|
|
|
|
|
/*
|
|
|
|
* VP9 Codec Definitions
|
|
|
|
*/
|
|
|
|
#if CONFIG_VP9
|
|
|
|
class VP9Decoder : public Decoder {
|
|
|
|
public:
|
|
|
|
VP9Decoder(vpx_codec_dec_cfg_t cfg, unsigned long deadline)
|
|
|
|
: Decoder(cfg, deadline) {}
|
|
|
|
|
|
|
|
protected:
|
2014-01-31 16:32:42 -08:00
|
|
|
virtual vpx_codec_iface_t* CodecInterface() const {
|
2013-01-18 11:51:12 -08:00
|
|
|
#if CONFIG_VP9_DECODER
|
|
|
|
return &vpx_codec_vp9_dx_algo;
|
|
|
|
#else
|
|
|
|
return NULL;
|
|
|
|
#endif
|
|
|
|
}
|
|
|
|
};
|
|
|
|
|
|
|
|
class VP9Encoder : public Encoder {
|
|
|
|
public:
|
|
|
|
VP9Encoder(vpx_codec_enc_cfg_t cfg, unsigned long deadline,
|
|
|
|
const unsigned long init_flags, TwopassStatsStore *stats)
|
|
|
|
: Encoder(cfg, deadline, init_flags, stats) {}
|
|
|
|
|
|
|
|
protected:
|
2014-01-31 16:32:42 -08:00
|
|
|
virtual vpx_codec_iface_t* CodecInterface() const {
|
2013-01-18 11:51:12 -08:00
|
|
|
#if CONFIG_VP9_ENCODER
|
|
|
|
return &vpx_codec_vp9_cx_algo;
|
|
|
|
#else
|
|
|
|
return NULL;
|
|
|
|
#endif
|
|
|
|
}
|
|
|
|
};
|
|
|
|
|
|
|
|
class VP9CodecFactory : public CodecFactory {
|
|
|
|
public:
|
|
|
|
VP9CodecFactory() : CodecFactory() {}
|
|
|
|
|
|
|
|
virtual Decoder* CreateDecoder(vpx_codec_dec_cfg_t cfg,
|
|
|
|
unsigned long deadline) const {
|
|
|
|
#if CONFIG_VP9_DECODER
|
|
|
|
return new VP9Decoder(cfg, deadline);
|
|
|
|
#else
|
|
|
|
return NULL;
|
|
|
|
#endif
|
|
|
|
}
|
|
|
|
|
|
|
|
virtual Encoder* CreateEncoder(vpx_codec_enc_cfg_t cfg,
|
|
|
|
unsigned long deadline,
|
|
|
|
const unsigned long init_flags,
|
|
|
|
TwopassStatsStore *stats) const {
|
|
|
|
#if CONFIG_VP9_ENCODER
|
|
|
|
return new VP9Encoder(cfg, deadline, init_flags, stats);
|
|
|
|
#else
|
|
|
|
return NULL;
|
|
|
|
#endif
|
|
|
|
}
|
|
|
|
|
|
|
|
virtual vpx_codec_err_t DefaultEncoderConfig(vpx_codec_enc_cfg_t *cfg,
|
|
|
|
int usage) const {
|
|
|
|
#if CONFIG_VP9_ENCODER
|
|
|
|
return vpx_codec_enc_config_default(&vpx_codec_vp9_cx_algo, cfg, usage);
|
|
|
|
#else
|
|
|
|
return VPX_CODEC_INCAPABLE;
|
|
|
|
#endif
|
|
|
|
}
|
|
|
|
};
|
|
|
|
|
|
|
|
const libvpx_test::VP9CodecFactory kVP9;
|
|
|
|
|
2013-07-02 14:14:16 -07:00
|
|
|
#define VP9_INSTANTIATE_TEST_CASE(test, ...)\
|
2013-01-18 11:51:12 -08:00
|
|
|
INSTANTIATE_TEST_CASE_P(VP9, test, \
|
|
|
|
::testing::Combine( \
|
|
|
|
::testing::Values(static_cast<const libvpx_test::CodecFactory*>( \
|
|
|
|
&libvpx_test::kVP9)), \
|
2013-07-02 14:14:16 -07:00
|
|
|
__VA_ARGS__))
|
2013-01-18 11:51:12 -08:00
|
|
|
#else
|
2013-07-02 14:14:16 -07:00
|
|
|
#define VP9_INSTANTIATE_TEST_CASE(test, ...)
|
2013-01-18 11:51:12 -08:00
|
|
|
#endif // CONFIG_VP9
|
|
|
|
|
|
|
|
|
|
|
|
} // namespace libvpx_test
|
|
|
|
|
|
|
|
#endif // TEST_CODEC_FACTORY_H_
|