Этот пример показывает, как инициализировать драйвер, считать несколько свойств драйвера и получить спектр сигнала с помощью анализатора спектра Rohde & Schwarz и визуализировать спектр в MATLAB ®.
Этот пример требует установки на компьютере следующего:
Rohde & Schwarz Spectrum Analyzer IVI-C x64 драйвер версии 1.0 или новее
Здесь перечисляются драйверы 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'
% 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);
Сконфигурируйте атрибуты связи и развертки анализатора спектра
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 для выполнения анализа, который может быть невозможен с помощью встроенной возможности оборудования.