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

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

Требования

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

  • Rohde & Schwarz Spectrum Analyzer 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);

Выполните свип

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

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 может использоваться, чтобы визуализировать и выполнить анализ данных, используя богатую библиотеку функций в Signal Processing Toolbox™ и Коммуникационные системы Toolbox™. Используя Instrument Control Toolbox™, можно автоматизировать управление инструментами, и, создать тестовые системы, которые используют MATLAB для выполнения анализа, который может быть невозможен с помощью встроенной возможности оборудования.

Для просмотра документации необходимо авторизоваться на сайте