/* 
 | 
 * RkAiqAieHandle.h 
 | 
 * 
 | 
 *  Copyright (c) 2019-2021 Rockchip Eletronics Co., Ltd. 
 | 
 * 
 | 
 * 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. 
 | 
 * 
 | 
 */ 
 | 
  
 | 
#include "RkAiqCore.h" 
 | 
#include "RkAiqHandle.h" 
 | 
  
 | 
namespace RkCam { 
 | 
  
 | 
void RkAiqAieHandle::init() { 
 | 
    ENTER_ANALYZER_FUNCTION(); 
 | 
  
 | 
    deInit(); 
 | 
    mConfig       = (RkAiqAlgoCom*)(new RkAiqAlgoConfigAie()); 
 | 
    mPreInParam   = (RkAiqAlgoCom*)(new RkAiqAlgoPreAie()); 
 | 
    mPreOutParam  = (RkAiqAlgoResCom*)(new RkAiqAlgoPreResAie()); 
 | 
    mProcInParam  = (RkAiqAlgoCom*)(new RkAiqAlgoProcAie()); 
 | 
    mProcOutParam = (RkAiqAlgoResCom*)(new RkAiqAlgoProcResAie()); 
 | 
    mPostInParam  = (RkAiqAlgoCom*)(new RkAiqAlgoPostAie()); 
 | 
    mPostOutParam = (RkAiqAlgoResCom*)(new RkAiqAlgoPostResAie()); 
 | 
  
 | 
    EXIT_ANALYZER_FUNCTION(); 
 | 
} 
 | 
  
 | 
XCamReturn RkAiqAieHandle::prepare() { 
 | 
    ENTER_ANALYZER_FUNCTION(); 
 | 
    XCamReturn ret            = XCAM_RETURN_NO_ERROR; 
 | 
    RkAiqAlgoDescription* des = (RkAiqAlgoDescription*)mDes; 
 | 
  
 | 
    ret = RkAiqHandle::prepare(); 
 | 
    RKAIQCORE_CHECK_RET(ret, "aie handle prepare failed"); 
 | 
  
 | 
    // TODO config aie common params 
 | 
    RkAiqAlgoConfigAie* aie_config = (RkAiqAlgoConfigAie*)mConfig; 
 | 
  
 | 
    // id != 0 means the thirdparty's algo 
 | 
    if (mDes->id != 0) { 
 | 
        ret = des->prepare(mConfig); 
 | 
        RKAIQCORE_CHECK_RET(ret, "aie algo prepare failed"); 
 | 
    } 
 | 
  
 | 
    EXIT_ANALYZER_FUNCTION(); 
 | 
    return ret; 
 | 
} 
 | 
  
 | 
XCamReturn RkAiqAieHandle::preProcess() { 
 | 
    ENTER_ANALYZER_FUNCTION(); 
 | 
    XCamReturn ret            = XCAM_RETURN_NO_ERROR; 
 | 
    RkAiqAlgoDescription* des = (RkAiqAlgoDescription*)mDes; 
 | 
    RkAiqAlgoPreAie* aie_pre  = (RkAiqAlgoPreAie*)mPreInParam; 
 | 
  
 | 
    ret = RkAiqHandle::preProcess(); 
 | 
    RKAIQCORE_CHECK_RET(ret, "aie handle preProcess failed"); 
 | 
  
 | 
    // TODO config common aie preprocess params 
 | 
  
 | 
    // id != 0 means the thirdparty's algo 
 | 
    if (mDes->id != 0) { 
 | 
        ret = des->pre_process(mPreInParam, mPreOutParam); 
 | 
        RKAIQCORE_CHECK_RET(ret, "aie handle pre_process failed"); 
 | 
    } 
 | 
  
 | 
    EXIT_ANALYZER_FUNCTION(); 
 | 
    return ret; 
 | 
} 
 | 
  
 | 
XCamReturn RkAiqAieHandle::processing() { 
 | 
    XCamReturn ret            = XCAM_RETURN_NO_ERROR; 
 | 
    RkAiqAlgoDescription* des = (RkAiqAlgoDescription*)mDes; 
 | 
    RkAiqAlgoProcAie* aie_pre = (RkAiqAlgoProcAie*)mProcInParam; 
 | 
  
 | 
    ret = RkAiqHandle::processing(); 
 | 
    RKAIQCORE_CHECK_RET(ret, "aie handle processing failed"); 
 | 
  
 | 
    // TODO config common aie processing params 
 | 
  
 | 
    // id != 0 means the thirdparty's algo 
 | 
    if (mDes->id != 0) { 
 | 
        ret = des->processing(mProcInParam, mProcOutParam); 
 | 
        RKAIQCORE_CHECK_RET(ret, "aie algo processing failed"); 
 | 
    } 
 | 
  
 | 
    EXIT_ANALYZER_FUNCTION(); 
 | 
    return ret; 
 | 
} 
 | 
  
 | 
XCamReturn RkAiqAieHandle::postProcess() { 
 | 
    ENTER_ANALYZER_FUNCTION(); 
 | 
    XCamReturn ret            = XCAM_RETURN_NO_ERROR; 
 | 
    RkAiqAlgoDescription* des = (RkAiqAlgoDescription*)mDes; 
 | 
    RkAiqAlgoPostAie* aie_pre = (RkAiqAlgoPostAie*)mPostInParam; 
 | 
  
 | 
    ret = RkAiqHandle::postProcess(); 
 | 
    RKAIQCORE_CHECK_RET(ret, "aie handle postProcess failed"); 
 | 
  
 | 
    // TODO config common aie postProcess params 
 | 
  
 | 
    // id != 0 means the thirdparty's algo 
 | 
    if (mDes->id != 0) { 
 | 
        ret = des->post_process(mPostInParam, mPostOutParam); 
 | 
        RKAIQCORE_CHECK_RET(ret, "aie algo postProcess failed"); 
 | 
    } 
 | 
  
 | 
    EXIT_ANALYZER_FUNCTION(); 
 | 
    return ret; 
 | 
} 
 | 
  
 | 
};  // namespace RkCam 
 |