7-20
IM 760101-11E
Call DisplayGPIBError(sts, msg)
GpibWaveFloat = 1
Exit Function
End If
'Wait for the completion of the data updating
msg = "COMMUNICATE:WAIT 1" + term
sts = ilwrt(Dev, msg, Len(msg)) 'Send Command
If (sts < 0) Then
Call DisplayGPIBError(sts, msg)
GpibWaveFloat = 1
Exit Function
End If
Next wait
'Set conditions for reading the waveform
'FLOAT(MSB first) format, Trace = U1
msg = "WAVEFORM:TRACE U1;FORMAT FLOAT;BYTEORDER MSBFIRST" + term
sts = ilwrt(Dev, msg, Len(msg)) 'Send Command
If (sts < 0) Then
Call DisplayGPIBError(sts, msg)
GpibWaveFloat = 1
Exit Function
End If
'Read and display the waveform data
eos = 0
sts = ileos(Dev, eos) 'Terminator = None(for Binary Data)
If (sts < 0) Then
Call DisplayGPIBError(sts, "ileos")
GpibWaveFloat = 1
Exit Function
End If
'Read in the waveform data
pntl = 1002
msg = "WAVEFORM:START 0;END 1001;SEND?" + term
sts = ilwrt(Dev, msg, Len(msg)) 'Send Command
If (sts < 0) Then
Call DisplayGPIBError(sts, msg)
GpibWaveFloat = 1
Exit Function
End If
sts = ilrdi(Dev, bufv(), 6 + 1002 * 4 + 1) 'Receive Query(Integer data)
If (sts < 0) Then
Call DisplayGPIBError(sts, msg)
GpibWaveFloat = 1
Exit Function
End If
eos = &HC0A
sts = ileos(Dev, eos) 'Terminator = LF
If (sts < 0) Then
Call DisplayGPIBError(sts, "ileos")
GpibWaveFloat = 1
Exit Function
End If
For i = 1 To pntl
buf = ""
For j = 1 To 2
If Left(Right("00" + Hex$(bufv((i * 2) + j)), 4), 2) = "00" Then
buf = buf + Right("00" + Hex$(bufv((i * 2) + j)), 4)
ElseIf Left(Right("0" + Hex$(bufv((i * 2) + j)), 4), 1) = "0" Then
buf = buf + Right("0" + Hex$(bufv((i * 2) + j)), 4)
Else
buf = buf + Hex$(bufv(2 + ((i - 1) * 2) + j))
End If
Next j
all = Mid(buf, 3, 2) + Mid(buf, 1, 2) + Mid(buf, 7, 2) + Mid(buf, 5, 2)
For k = 1 To 8
a(k) = Mid$(all, k, 1)
If a(k) = "0" Then b(k) = "0000"
If a(k) = "1" Then b(k) = "0001"
If a(k) = "2" Then b(k) = "0010"
If a(k) = "3" Then b(k) = "0011"
If a(k) = "4" Then b(k) = "0100"
If a(k) = "5" Then b(k) = "0101"
If a(k) = "6" Then b(k) = "0110"
If a(k) = "7" Then b(k) = "0111"
If a(k) = "8" Then b(k) = "1000"
If a(k) = "9" Then b(k) = "1001"
If a(k) = "A" Then b(k) = "1010"
If a(k) = "B" Then b(k) = "1011"
If a(k) = "C" Then b(k) = "1100"
If a(k) = "D" Then b(k) = "1101"
If a(k) = "E" Then b(k) = "1110"
If a(k) = "F" Then b(k) = "1111"
Next k
allb = b(1) + b(2) + b(3) + b(4) + b(5) + b(6) + b(7) + b(8)
vale = 0
valf = 0
valu = Val(Left$(allb, 1))
stre = Mid$(allb, 2, 8)
7.7 Output of Waveform Data (FLOAT Format)
Summary of Contents for wt1600
Page 1: ...Digital Power Meter Communication Interface IM 760101 11E 4th Edition ...
Page 131: ...7 2 IM 760101 11E 7 2 Sample Program Image ...
Page 138: ...Sample Program 7 9 IM 760101 11E 7 7 4 Output of Normal Measurement Data ...
Page 142: ...Sample Program 7 13 IM 760101 11E 7 7 5 Output of Harmonic Measurement Data ...