⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 age1968a.cpp

📁 MTK 手机软件开发 META 源代码,开发环境: C++ Builder
💻 CPP
📖 第 1 页 / 共 3 页
字号:
/*****************************************************************************
*  Copyright Statement:
*  --------------------
*  This software is protected by Copyright and the information contained
*  herein is confidential. The software may not be copied and the information
*  contained herein may not be used or disclosed except with the written
*  permission of MediaTek Inc. (C) 2005
*
*  BY OPENING THIS FILE, BUYER HEREBY UNEQUIVOCALLY ACKNOWLEDGES AND AGREES
*  THAT THE SOFTWARE/FIRMWARE AND ITS DOCUMENTATIONS ("MEDIATEK SOFTWARE")
*  RECEIVED FROM MEDIATEK AND/OR ITS REPRESENTATIVES ARE PROVIDED TO BUYER ON
*  AN "AS-IS" BASIS ONLY. MEDIATEK EXPRESSLY DISCLAIMS ANY AND ALL WARRANTIES,
*  EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE IMPLIED WARRANTIES OF
*  MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE OR NONINFRINGEMENT.
*  NEITHER DOES MEDIATEK PROVIDE ANY WARRANTY WHATSOEVER WITH RESPECT TO THE
*  SOFTWARE OF ANY THIRD PARTY WHICH MAY BE USED BY, INCORPORATED IN, OR
*  SUPPLIED WITH THE MEDIATEK SOFTWARE, AND BUYER AGREES TO LOOK ONLY TO SUCH
*  THIRD PARTY FOR ANY WARRANTY CLAIM RELATING THERETO. MEDIATEK SHALL ALSO
*  NOT BE RESPONSIBLE FOR ANY MEDIATEK SOFTWARE RELEASES MADE TO BUYER'S
*  SPECIFICATION OR TO CONFORM TO A PARTICULAR STANDARD OR OPEN FORUM.
*
*  BUYER'S SOLE AND EXCLUSIVE REMEDY AND MEDIATEK'S ENTIRE AND CUMULATIVE
*  LIABILITY WITH RESPECT TO THE MEDIATEK SOFTWARE RELEASED HEREUNDER WILL BE,
*  AT MEDIATEK'S OPTION, TO REVISE OR REPLACE THE MEDIATEK SOFTWARE AT ISSUE,
*  OR REFUND ANY SOFTWARE LICENSE FEES OR SERVICE CHARGE PAID BY BUYER TO
*  MEDIATEK FOR SUCH MEDIATEK SOFTWARE AT ISSUE.
*
*  THE TRANSACTION CONTEMPLATED HEREUNDER SHALL BE CONSTRUED IN ACCORDANCE
*  WITH THE LAWS OF THE STATE OF CALIFORNIA, USA, EXCLUDING ITS CONFLICT OF
*  LAWS PRINCIPLES.  ANY DISPUTES, CONTROVERSIES OR CLAIMS ARISING THEREOF AND
*  RELATED THERETO SHALL BE SETTLED BY ARBITRATION IN SAN FRANCISCO, CA, UNDER
*  THE RULES OF THE INTERNATIONAL CHAMBER OF COMMERCE (ICC).
*
*****************************************************************************/
/*****************************************************************************
 *
 * Filename:
 * ---------
 *   Age1968a.cpp
 *
 * Project:
 * --------
 *   Maui META APP
 *
 * Description:
 * ------------
 *  Agilent 1968A software utility source
 *
 * Author:
 * -------
 *  Andy Ueng (mtk00490)
 *
 *============================================================================
 *             HISTORY
 * Below this line, this part is controlled by PVCS VM. DO NOT MODIFY!!
 *------------------------------------------------------------------------------
 * $Revision$
 * $Modtime$
 * $Log$
 * 
 *------------------------------------------------------------------------------
 * Upper this line, this part is controlled by PVCS VM. DO NOT MODIFY!!
 *============================================================================
 ****************************************************************************/

#include <vcl.h>
#include <math.h>
#include "visatype.h"
#include "visa.h"
#include "age1960.h"

#pragma hdrstop

#include "man_dll.h"
#include "meta_utils.h"
#include "meta_msg.h"
#include "Age1968A.h"
#include "AgeCommon.h"

#ifndef  _VISA_COMMON_H_
#include "visa_common.h"
#endif

// misc
#ifndef  _FT_UTILS_H_
#include "ft_utils.h"
#endif

#ifndef  _GSM_UTILS_H_
#include "gsm_utils.h"
#endif

#pragma package(smart_init)

//---------------------------------------------------------------------------
ViStatus age1968A_operatingMode(ViSession vi, E_AGE_OPERATING_MODE OperatingMode)
{
    AnsiString asOperatingMode;
    ViStatus vistat;

    switch (OperatingMode)
    {
        case OPERATING_MODE_ACTIVE:
        {
            asOperatingMode = "CALL:OPERating:MODE CALL";
        }
        break;

        case OPERATING_MODE_GSM_CW:
        {
            asOperatingMode = "CALL:OPERating:MODE CW";
        }
        break;

        case OPERATING_MODE_GSM_BCH:
        {
            asOperatingMode = "CALL:OPERating:MODE GBTest";
        }
        break;

        case OPERATING_MODE_GSM_BCH_TCH:
        {
             asOperatingMode = "CALL:OPERATING:MODE GBTTest";
        }
        break;

        case OPERATING_MODE_GPRS_BCH:
        {
             asOperatingMode = "CALL:OPERATING:MODE PBTest";
        }
        break;

        case OPERATING_MODE_GPRS_BCH_PDTCH:
        {
             asOperatingMode = "CALL:OPERATING:MODE PBPTest";
        }
        break;

        case OPERATING_MODE_EGPRS_BCH:
        {
             asOperatingMode = "CALL:OPERATING:MODE EBTest";
        }
        break;

        case OPERATING_MODE_EGPRS_BCH_PDTCH:
        {
             asOperatingMode = "CALL:OPERATING:MODE EBPTest";
        }
        break;

        default:
        {
             asOperatingMode = "CALL:OPERATING:MODE GBTTest";
        }
        break;
    }

    vistat = age1960_cmd(vi, asOperatingMode.c_str());
    if (vistat != VI_SUCCESS)
    {
        return vistat;
    }

    return VI_SUCCESS;
}

//===========================================================================
////////////////////////////    CW mode      ////////////////////////////////
//===========================================================================
ViStatus age1968A_cellPower_CW(ViSession vi, double dBm)
{
    AnsiString as_cmd = "CALL:POWer:CW " + Double_To_AnsiString(dBm);
    ViStatus vistat = age1960_cmd(vi, as_cmd.c_str());
    if (vistat != VI_SUCCESS)
    {
        return vistat;
    }

    return VI_SUCCESS;
}

//---------------------------------------------------------------------------
ViStatus age1968A_GenFreq_CW(ViSession vi, FrequencyBand FreqBand, short arfcn)
{
    double d_CenterFreq;
    getCenterFreq(FreqBand, arfcn, false, &d_CenterFreq);
    AnsiString as_cmd = "CALL:CELL:RFGENERATOR:FREQUENCY:SELECTED " + Double_To_AnsiString(d_CenterFreq) + "MHZ";
    ViStatus vistat = age1960_cmd(vi, as_cmd.c_str());
    if (vistat != VI_SUCCESS)
    {
        return vistat;
    }

    return VI_SUCCESS;
}

//===========================================================================
/////////////////////////          PDTCH     ////////////////////////////////
//===========================================================================
ViStatus age1968A_PDTCHMSTargetPower(ViSession vi, double dBm)
{
    AnsiString as_cmd;
    ViStatus vistat;

    as_cmd = "RFAN:CONT:POW:AUTO OFF";
    vistat = age1960_cmd(vi,as_cmd.c_str());
    if (vistat != VI_SUCCESS)
    {
        return vistat;
    }

    as_cmd = "RFAN:MAN:POW:BURS " + Double_To_AnsiString(dBm);
    vistat = age1960_cmd(vi,as_cmd.c_str());
    if (vistat != VI_SUCCESS)
    {
        return vistat;
    }
    
    return VI_SUCCESS;
}

//---------------------------------------------------------------------------
ViStatus age1968A_PDTCHMSTxLevel(ViSession vi, int i_PCL)
{
    AnsiString as_cmd;
    ViStatus vistat;

    as_cmd = "RFAN:CONT:POW:AUTO ON";
    vistat = age1960_cmd(vi,as_cmd.c_str());
    if (vistat != VI_SUCCESS)
    {
        return vistat;
    }

    as_cmd = "CALL:PDTCH:MS:TXLevel:BURSt " + IntToStr(i_PCL);
    vistat = age1960_cmd(vi,as_cmd.c_str());
    if (vistat != VI_SUCCESS)
    {
        return vistat;
    }

    return VI_SUCCESS;
}

//---------------------------------------------------------------------------
ViStatus age1968A_PDTCHARFCN(ViSession vi, short s_ARFCN)
{
    AnsiString as_cmd;
    ViStatus vistat;

    as_cmd = "CALL:PDTCH:ARFCn:SELected " + IntToStr(s_ARFCN);
    vistat = age1960_cmd( vi,as_cmd.c_str());
    if (vistat != VI_SUCCESS)
    {
        return vistat;
    }


    return VI_SUCCESS;

}

//===========================================================================
//////////////////////////////// TX power  //////////////////////////////////
//===========================================================================
ViStatus age1968A_Config_ExpectedTxPower(ViSession vi, bool b_auto_control, double d_expected_power)
{
    AnsiString as_cmd;
    ViStatus vistat;

    if (b_auto_control)
    {
        as_cmd = "RFANalyzer:CONTrol:POWer:AUTO ON";
        vistat = age1960_cmd( vi,as_cmd.c_str());
        if (vistat != VI_SUCCESS)
        {
            return vistat;
        }
    }
    else
    {
        as_cmd = "RFANalyzer:CONTrol:POWer:AUTO OFF";
        vistat = age1960_cmd(vi,as_cmd.c_str());
        if (vistat != VI_SUCCESS)
        {
            return vistat;
        }

        as_cmd = "RFANalyzer:MANual:POWer:BURSt " + Double_To_AnsiString(d_expected_power);
        vistat = age1960_cmd(vi,as_cmd.c_str());
        if (vistat != VI_SUCCESS)
        {
            return vistat;
        }
    }

    return VI_SUCCESS;
}

//--------------------------------------------------------------------------
ViStatus age1968A_initMeasFcn_EGPRS_TXPOWER(ViSession vi)
{
    AnsiString as_cmd;
    ViStatus vistat;

    as_cmd = "INITIATE:ETXPOWER";
    vistat = age1960_cmd( vi,as_cmd.c_str());
    if (vistat != VI_SUCCESS)
    {
        return vistat;
    }

    return VI_SUCCESS;
}

//---------------------------------------------------------------------------
ViStatus age1968A_TXPowerContOn(ViSession vi)
{
    AnsiString as_cmd;
    ViStatus vistat;

    as_cmd = "SET:TXPower:CONT ON";
    vistat = age1960_cmd(vi, as_cmd.c_str());
    if (vistat != VI_SUCCESS)
    {
        return vistat;
    }

    return VI_SUCCESS;
}

//---------------------------------------------------------------------------
ViStatus age1968A_TXPowerContOff(ViSession vi)
{
    AnsiString as_cmd;
    ViStatus vistat;

    as_cmd = "SET:TXPower:CONT OFF";
    vistat = age1960_cmd(vi, as_cmd.c_str());
    if (vistat != VI_SUCCESS)
    {
        return vistat;
    }

    return VI_SUCCESS;
}

//---------------------------------------------------------------------------
ViStatus age1968A_EPSK_TXPowerContOn(ViSession vi)
{
    AnsiString as_cmd;
    ViStatus vistat;

    as_cmd = "SET:ETXPower:CONT ON";
    vistat = age1960_cmd(vi, as_cmd.c_str());
    if (vistat != VI_SUCCESS)
    {
        return vistat;
    }

    return VI_SUCCESS;
}

//---------------------------------------------------------------------------
ViStatus age1968A_EPSK_TXPowerContOff(ViSession vi)
{
    AnsiString as_cmd;
    ViStatus vistat;

    as_cmd = "SET:ETXPower:CONT OFF";
    vistat = age1960_cmd(vi, as_cmd.c_str());
    if (vistat != VI_SUCCESS)
    {
        return vistat;
    }

    return VI_SUCCESS;
}

//---------------------------------------------------------------------------
ViStatus age1968A_ConfigTxPower(ViSession vi, int iMeasureCount, int iTriSour, int iDelay, int iTriQual, int iTimeout)
{
    AnsiString asTXPowerSnum, asTXPowerTriSour, asTXPowerTimeout, asTXPowerDelay, asTXPowerTriQual;
    ViStatus vistat;

    // set measurecount
    asTXPowerSnum = "SETUP:TXPOWER:COUNT:SNUMBER " + IntToStr(iMeasureCount);
    vistat = age1960_cmd(vi,asTXPowerSnum.c_str());
    if (vistat != VI_SUCCESS)
    {
        return vistat;
    }

    // triger source
    switch (iTriSour)
    {
     	case age1960_TRIG_AUTO:
        {
     	    asTXPowerTriSour = "SETUP:TXPOWER:TRIGGER:SOURCE AUTO";
        }
     	break;

     	case age1960_TRIG_PROT:
        {
     	    asTXPowerTriSour = "SETUP:TXPOWER:TRIGGER:SOURCE PROTocol";
        }
     	break;

     	case age1960_TRIG_RF_RISE:
        {
     	    asTXPowerTriSour = "SETUP:TXPOWER:TRIGGER:SOURCE RISE";
        }
     	break;

     	case age1960_TRIG_IMMEDIATE:
        {
     	    asTXPowerTriSour = "SETUP:TXPOWER:TRIGGER:SOURCE IMMediate";
        }
     	break;

     	default: // set to auto
        {
     	    asTXPowerTriSour = "SETUP:TXPOWER:TRIGGER:SOURCE AUTO";
        }
     	break;
    }

    vistat = age1960_cmd(vi,asTXPowerTriSour.c_str());
    if (vistat != VI_SUCCESS)

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -