📄 age1968a.cpp
字号:
/*****************************************************************************
* 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 + -