207 lines
5.6 KiB
C++
Executable File
207 lines
5.6 KiB
C++
Executable File
/*
|
|
* aiq_wrapper.cpp - aiq wrapper:
|
|
*
|
|
* Copyright (c) 2015 Intel Corporation
|
|
*
|
|
* Licensed under the Apache License, Version 2.0 (the "License");
|
|
* you may not use this file except in compliance with the License.
|
|
* You may obtain a copy of the License at
|
|
*
|
|
* http://www.apache.org/licenses/LICENSE-2.0
|
|
*
|
|
* Unless required by applicable law or agreed to in writing, software
|
|
* distributed under the License is distributed on an "AS IS" BASIS,
|
|
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
* See the License for the specific language governing permissions and
|
|
* limitations under the License.
|
|
*
|
|
* Author: Jia Meng <jia.meng@intel.com>
|
|
*/
|
|
|
|
#include <base/xcam_3a_description.h>
|
|
#include <xcam_std.h>
|
|
|
|
using namespace XCam;
|
|
|
|
#define CONTEXT_CAST(context) ((XCam3AHybridContext*)(context))
|
|
|
|
class XCam3AHybridContext
|
|
{
|
|
public:
|
|
XCam3AHybridContext ();
|
|
~XCam3AHybridContext ();
|
|
|
|
private:
|
|
XCAM_DEAD_COPY (XCam3AHybridContext);
|
|
|
|
};
|
|
|
|
XCam3AHybridContext::XCam3AHybridContext ()
|
|
{
|
|
}
|
|
|
|
XCam3AHybridContext::~XCam3AHybridContext ()
|
|
{
|
|
}
|
|
|
|
static XCamReturn
|
|
xcam_create_context (XCam3AContext **context)
|
|
{
|
|
XCAM_ASSERT (context);
|
|
XCam3AHybridContext *ctx = new XCam3AHybridContext ();
|
|
*context = ((XCam3AContext*)(ctx));
|
|
return XCAM_RETURN_NO_ERROR;
|
|
}
|
|
|
|
static XCamReturn
|
|
xcam_destroy_context (XCam3AContext *context)
|
|
{
|
|
XCam3AHybridContext *ctx = CONTEXT_CAST (context);
|
|
delete ctx;
|
|
return XCAM_RETURN_NO_ERROR;
|
|
}
|
|
|
|
// configure customized 3a analyzer with width/height/framerate
|
|
static XCamReturn
|
|
xcam_configure_3a (XCam3AContext *context, void* dev, void* isp_stats_dev, void* isp_params_dev, uint32_t width, uint32_t height, double framerate)
|
|
{
|
|
XCAM_UNUSED (context);
|
|
XCAM_UNUSED (width);
|
|
XCAM_UNUSED (height);
|
|
XCAM_UNUSED (framerate);
|
|
|
|
return XCAM_RETURN_NO_ERROR;
|
|
}
|
|
|
|
// set 3a stats to customized 3a analyzer for subsequent usage
|
|
static XCamReturn
|
|
xcam_set_3a_stats (XCam3AContext *context, XCam3AStats *stats, int64_t timestamp)
|
|
{
|
|
XCAM_UNUSED (context);
|
|
XCAM_UNUSED (timestamp);
|
|
/*
|
|
XCam3AStatsInfo info = stats->info;
|
|
for (uint32_t i = 0; i < info.height; ++i)
|
|
for (uint32_t j = 0; j < info.width; ++j) {
|
|
XCAM_LOG_DEBUG ("%d %d %d %d %d %d %d %d",
|
|
stats->stats[i * info.aligned_width + j].avg_y,
|
|
stats->stats[i * info.aligned_width + j].avg_gr,
|
|
stats->stats[i * info.aligned_width + j].avg_r,
|
|
stats->stats[i * info.aligned_width + j].avg_b,
|
|
stats->stats[i * info.aligned_width + j].avg_gb,
|
|
stats->stats[i * info.aligned_width + j].valid_wb_count,
|
|
stats->stats[i * info.aligned_width + j].f_value1,
|
|
stats->stats[i * info.aligned_width + j].f_value2);
|
|
}
|
|
*/
|
|
return XCAM_RETURN_NO_ERROR;
|
|
}
|
|
|
|
// refer to xcam_params.h for common parameters
|
|
static XCamReturn
|
|
xcam_update_common_params (XCam3AContext *context, XCamCommonParam *params)
|
|
{
|
|
XCAM_UNUSED (context);
|
|
XCAM_UNUSED (params);
|
|
|
|
return XCAM_RETURN_NO_ERROR;
|
|
}
|
|
|
|
// customized awb algorithm should be added here
|
|
static XCamReturn
|
|
xcam_analyze_awb (XCam3AContext *context, XCamAwbParam *params)
|
|
{
|
|
XCAM_UNUSED (context);
|
|
XCAM_UNUSED (params);
|
|
|
|
return XCAM_RETURN_NO_ERROR;
|
|
}
|
|
|
|
// customized ae algorithm should be added here
|
|
static XCamReturn
|
|
xcam_analyze_ae (XCam3AContext *context, XCamAeParam *params)
|
|
{
|
|
XCAM_UNUSED (context);
|
|
XCAM_UNUSED (params);
|
|
|
|
return XCAM_RETURN_NO_ERROR;
|
|
}
|
|
|
|
// customized af is unsupported now
|
|
static XCamReturn
|
|
xcam_analyze_af (XCam3AContext *context, XCamAfParam *params)
|
|
{
|
|
XCAM_UNUSED (context);
|
|
XCAM_UNUSED (params);
|
|
|
|
return XCAM_RETURN_NO_ERROR;
|
|
}
|
|
|
|
// combine ae/awb analyze results and set to framework
|
|
// only support XCam3aResultExposure and XCam3aResultWhiteBalance now
|
|
static XCamReturn
|
|
xcam_combine_analyze_results (XCam3AContext *context, XCam3aResultHead *results[], uint32_t *res_count)
|
|
{
|
|
XCAM_UNUSED (context);
|
|
|
|
uint32_t result_count = 2;
|
|
static XCam3aResultHead *res_array[XCAM_3A_MAX_RESULT_COUNT];
|
|
xcam_mem_clear (res_array);
|
|
|
|
for (uint32_t i = 0; i < result_count; ++i) {
|
|
results[i] = res_array[i];
|
|
}
|
|
*res_count = result_count;
|
|
|
|
XCam3aResultExposure *exposure = xcam_malloc0_type (XCam3aResultExposure);
|
|
XCAM_ASSERT (exposure);
|
|
exposure->head.type = XCAM_3A_RESULT_EXPOSURE;
|
|
exposure->head.process_type = XCAM_IMAGE_PROCESS_ALWAYS;
|
|
exposure->head.version = XCAM_VERSION;
|
|
exposure->exposure_time = 9986; // 9.986ms
|
|
exposure->analog_gain = 10;
|
|
results[0] = (XCam3aResultHead *)exposure;
|
|
|
|
XCam3aResultWhiteBalance *wb = xcam_malloc0_type (XCam3aResultWhiteBalance);
|
|
XCAM_ASSERT (wb);
|
|
wb->head.type = XCAM_3A_RESULT_WHITE_BALANCE;
|
|
wb->head.process_type = XCAM_IMAGE_PROCESS_ALWAYS;
|
|
wb->head.version = XCAM_VERSION;
|
|
wb->gr_gain = 1.0;
|
|
wb->r_gain = 1.6453;
|
|
wb->b_gain = 2.0645;
|
|
wb->gb_gain = 1.0;
|
|
results[1] = (XCam3aResultHead *)wb;
|
|
|
|
return XCAM_RETURN_NO_ERROR;
|
|
}
|
|
|
|
static void
|
|
xcam_free_results (XCam3aResultHead *results[], uint32_t res_count)
|
|
{
|
|
for (uint32_t i = 0; i < res_count; ++i) {
|
|
if (results[i])
|
|
xcam_free (results[i]);
|
|
}
|
|
}
|
|
|
|
XCAM_BEGIN_DECLARE
|
|
|
|
XCam3ADescription xcam_3a_desciption = {
|
|
XCAM_VERSION,
|
|
sizeof (XCam3ADescription),
|
|
xcam_create_context,
|
|
xcam_destroy_context,
|
|
xcam_configure_3a,
|
|
xcam_set_3a_stats,
|
|
xcam_update_common_params,
|
|
xcam_analyze_awb,
|
|
xcam_analyze_ae,
|
|
xcam_analyze_af,
|
|
xcam_combine_analyze_results,
|
|
xcam_free_results
|
|
};
|
|
|
|
XCAM_END_DECLARE
|
|
|