exponenta event banner

Получение спектра сигнала на анализаторе спектра Rohde & Schwarz ® с помощью драйвера IVI-C

В этом примере показано, как инициализировать драйвер, прочитать несколько свойств драйвера и получить спектр сигнала с помощью анализатора спектра Rohde & Schwarz и визуализировать спектр в MATLAB ®.

Требования

В этом примере требуется установить на компьютере следующее:

  • Анализатор спектра Rohde & Schwarz IVI-C x64 версии 1.0 или более поздней

Перечисление доступных драйверов IVI-C на компьютере

Здесь перечислены драйверы IVI, установленные на компьютере.

IviInfo = instrhwinfo('ivi');
IviInfo.Modules
ans = 

  Columns 1 through 6

    'Ag33220'    'Ag3352x'    'Ag34410'    'Ag34970'    'Ag532xx'    'AgAC6800'

  Columns 7 through 11

    'AgE36xx'    'AgInfiniiVision'    'AgMD1'    'AgRfSigGen'    'AgXSAn'

  Columns 12 through 13

    'KtRFPowerMeter'    'rsspecan'

Создание драйвера прибора MATLAB и подключение к прибору

% Create the MATLAB instrument driver
makemid('rsspecan','rsspecan.mdd')

% Use icdevice with the MATLAB instrument driver name and instrument's
% resource name to create a device object. In this example the instrument
% is connected by GPIB at board index 0 and primary address 1.
myInstrument = icdevice('rsspecan.mdd', 'GPIB0::01::INSTR','optionstring','simulate=true');

% Connect driver instance
connect(myInstrument);

Получить общие свойства устройства

Запрос информации о водителе и приборе

Utility = get(myInstrument,'Utility');
InherentIviAttributesInstrumentIdentification = get(myInstrument, 'Inherentiviattributesinstrumentidentification');
InherentIviAttributesDriverIdentification = get(myInstrument,'Inherentiviattributesdriveridentification');
Revision = get(InherentIviAttributesDriverIdentification, 'Revision');
Vendor = get(InherentIviAttributesDriverIdentification, 'Driver_Vendor');
Description = get(InherentIviAttributesDriverIdentification, 'Description');
InstrumentModel = get(InherentIviAttributesInstrumentIdentification, 'Model');
FirmwareRev = get(InherentIviAttributesInstrumentIdentification, 'Firmware_Revision');
% Print the queried driver properties
fprintf('Revision:        %s\n', Revision);
fprintf('Vendor:          %s\n', Vendor);
fprintf('Description:     %s\n', Description);
fprintf('InstrumentModel: %s\n', InstrumentModel);
fprintf('FirmwareRev:     %s\n', FirmwareRev);
fprintf(' \n');
Revision:        Driver: rsspecan 1.0 (1.0.0.14), Compiler: CVI 13.00, Components: IVIEngine 14.00, VISA-Spec 5.40
Vendor:          Rohde&Schwarz
Description:     Rohde & Schwarz Signal and Spectrum Analyzer IVI-C Driver
InstrumentModel: FSW-26
FirmwareRev:     1.30
 

Определение атрибутов и переменных

% These constants are defined in the IVI header file 'IviSpecAn.h'
IVISPECAN_VAL_DETECTOR_TYPE_AUTO_PEAK = 1;
IVISPECAN_VAL_VERTICAL_SCALE_LINEAR = 1;
IVISPECAN_VAL_AMPLITUDE_UNITS_DBM = 1;

Настройка центральной частоты и диапазона

Сконфигурируйте диапазон частот анализатора спектра с использованием центральной частоты и диапазона частот.

FrequencyCenter = 2E+9;
FrequencySpan = 500E+6;
Configuration = get(myInstrument, 'Configuration');
invoke(Configuration, 'configurefrequencycenterspan', FrequencyCenter,FrequencySpan);

Настройка одиночного сдвига

Сконфигурируйте атрибуты сбора данных анализатора спектра.

SweepModeContinuous = false;
NumberOfSweeps = 1;
DetectorTypeAuto = true;
DetectorType = IVISPECAN_VAL_DETECTOR_TYPE_AUTO_PEAK;
VerticalScale = IVISPECAN_VAL_VERTICAL_SCALE_LINEAR;
Configuration = get(myInstrument, 'Configuration');
invoke(Configuration, 'configureacquisition', SweepModeContinuous,NumberOfSweeps,DetectorTypeAuto,DetectorType,VerticalScale);

Настройка опорного уровня и диапазона

Сконфигурируйте вертикальные атрибуты анализатора спектра. Это соответствует таким характеристикам, как амплитудные единицы, затухание на входе, входной импеданс, опорный уровень и смещение опорного уровня.

AmplitudeUnits = IVISPECAN_VAL_AMPLITUDE_UNITS_DBM;
InputImpedance = 50.0;
ReferenceLevel = -10.0;
ReferenceLevelOffset = 0;
AttenuationAuto = false;
Attenuation = 10.0;
invoke(Configuration, 'configurelevel', AmplitudeUnits, InputImpedance, ReferenceLevel, ReferenceLevelOffset, AttenuationAuto, Attenuation);

Настройка пропускной способности разрешения (RBW), пропускной способности видео (VBW) и времени сдвига

Конфигурирование атрибутов связи и развертки анализатора спектра

ResolutionBandwidthAuto = false;
ResolutionBandwidth = 1.0E+6;
VideoBandwidthAuto = false;
VideoBandwidth = 1.0E+6;
SweepTimeAuto = false;
SweepTime = 5.0E-3;
invoke(Configuration, 'configuresweepcoupling', ResolutionBandwidthAuto,ResolutionBandwidth,VideoBandwidthAuto,VideoBandwidth,SweepTimeAuto,SweepTime);

Выполнение сдвига

Инициируйте получение сигнала на основе текущей конфигурации прибора. Затем он ожидает завершения сбора данных и возвращает трассу в виде массива значений амплитуды. Амплитудная матрица возвращает данные, которые представляют амплитуду сигналов развертки от начальной частоты до конечной частоты. Атрибут «Единицы амплитуды» определяет единицы измерения точек в массиве амплитуд.

Tracename = 0;
MaximumTimeMs = 5000;
ArrayLength = 501;
AmplitudeX = 1.75e+09:0.1e+07:2.25e+09;
AmplitudeY = zeros(ArrayLength,1);
Measurement = get(myInstrument, 'Measurement');
[ActualPointsY,AmplitudeY] = invoke(Measurement, 'readytrace', Tracename,MaximumTimeMs,ArrayLength,AmplitudeY);

Визуализация данных и отображение любых ошибок

% Display the acquired spectrum
plot(AmplitudeX,AmplitudeY);
title('Spectrum Analyzer Trace Plot');
xlabel('Frequency (Hz)');
ylabel('Amplitude (dBm)');

% If there are any errors, query the driver to retrieve and display them.
ErrorNum = 1;
while (ErrorNum ~= 0)
    [ErrorNum, ErrorMsg] = invoke(Utility, 'errorquery');
    fprintf('ErrorQuery: %d, %s\n', ErrorNum, ErrorMsg);
end
ErrorQuery: 0, No error. 

Отключить объект устройства и очистить

disconnect(myInstrument);
% Remove instrument objects from memory.
delete(myInstrument);

Дополнительная информация:

В этом примере показана настройка и получение данных из анализатора спектра с использованием драйвера IVI. После извлечения измеренного спектра из прибора MATLAB может использоваться для визуализации и выполнения анализа данных с использованием богатой библиотеки функций в Toolbox™ Toolbox™ обработки сигналов и систем связи. С помощью Toolbox™ управления приборами можно автоматизировать управление приборами и создать тестовые системы, использующие MATLAB для выполнения анализа, который может оказаться невозможным с использованием встроенных возможностей аппаратных средств.