 
    
    
    
    Keithley 2400 GPIB-USB-HS
I am wondering if it is possible to control a Keithley 2400 SMU using a GPIB-USB-HS connector and the VISA extension in Igor. I have activated the VISA extension and see no indication that Igor is communicating with the instrument when I run the VISA XOP tests. I am running Igor 6.36 on Windows 7.
Any thoughts/ideas?
Thank you in advance.

 
I'm not sure what tests you are referring to. The example code in the documentation for viFindRsrc or viStatusDesc would be a good place to start.
June 1, 2015 at 12:14 pm - Permalink
I am able to communicate to the Keithley sourcemeter now evidenced by my ability to read and write attributes. However, now I cannot figure out how I actually send SCPI commands to the sourcemeter. If I wanted to send the keithley source meter "*IDN?" and save its output to a variable, how could I do that?
Thank you again for your help.
June 2, 2015 at 11:09 am - Permalink
Use the VISAWrite operation, and make sure to use the correct terminator - probably "\r\n".
Then use the VISARead operation to read into a string variable.
Read the documentation for VISAWrite and VISARead before proceeding.
June 2, 2015 at 11:46 am - Permalink
For those looking to start with a copy-and-paste IGOR code that works, try this:
NOTE: The code just gets your instrument name and enables and disables the front panel display.
June 2, 2015 at 02:35 pm - Permalink
One note ... VISARead can read into either a numeric or string variable. If you know that the answer from the instrument is numeric, you can provide a local numeric variable as the parameter to VISARead. That way you don't need to do the string-to-number conversion yourself.
June 2, 2015 at 06:09 pm - Permalink
I am successfully sending SCPI commands to the sourcemeter to acquire 20 voltage measurements.
After taking the 20 voltage readings, I send the Query ":TRAC:DATA?", which requests the raw data in the buffer.
Now, if I store that data in a string variable, I can read up to 10 values and print those values successfully without a problem using VISARead:
If I do more than 10 values, I get the "-410 Error Query Interrupted," indicating that I did not read all of the data in the buffer. The obvious solution is to store the data in a wave, but when I try VISAReadWave Igor freezes and stops responding. Here is the code I used to try and store the data in a wave:
This just makes Igor freeze and I have to force close it. I suspect it has something to do with the termination character or the data type. I have termination character disabled and "Send End on Writes" enabled, if that helps. Unless I need to use the RQS or EOI from the status byte, but I really have no idea how to implement that.
Thanks for your help. My full code is below:
June 5, 2015 at 02:25 pm - Permalink
To really know what you are doing, you need to know the precise format of the data being sent by the device, including any separators and terminators. By default VISAReadWave expects either a comma, tab, or carriage return after each number (see /T flag documentation). If the instrument is using something else, for example, linefeeds, you would need to use the /T flag to accommodate that (e.g., /T=",\t\r\n" for comma, tab, CR or LF).
This makes a 128-point wave. This means that VISAReadWave will try to read 128 numbers with a terminator, as specified by /T, after each one. You should use the Make/N flag to set the number of points in the wave which also controls the number of reads done by VISAReadWave.
Try setting the timeout for a read. According to viRead in http://www.ni.com/pdf/manuals/370132c.pdf, you set this by calling viSetAttribute with the attribute VI_ATTR_TMO_VALUE. See the VISA XOP viSetAttribute documentation for an example of setting an attribute. You can also use viGetAttribute to see what the default timeout is.
You'll find some useful discussion of timeouts and terminators by searching for "Keithley VI_ATTR_TMO_VALUE". This is the first hit and provides some useful information: http://www.keithley.com/data?asset=14711
June 5, 2015 at 03:48 pm - Permalink
"+2.000031E+01,+2.000031E+01,+2.000031E+01,+2.000031E+01,+2.000031E+01,+2.000031E+01,+2.000031E+01,+2.000030E+01,+2.000030E+01,+2.000029E+01,+2.000029E+01"
The output in my wave is this:
dataValues[0]= {20.0003,20.0003,20.0003,20.0003,20.0003,20.0003,20.0003,20.0003,20.0003,20.0003,3.47032e-308}
I don't know why Igor would have a problem with anything greater than 10 values. I can even do multiple columns for other data, but more than 10 rows is a problem. I set my timeout to 10 seconds, which is more than enough time.
I greatly appreciate the help; this is causing me a lot of frustration and wasted time. Here is my code:
June 8, 2015 at 12:29 pm - Permalink
I presume that you don't know what change preceded the problem. It may be something in the instrument itself rather than in your procedure.
It might be that you changed some setting in the instrument which allowed it to work and then changed the setting back or reset the instrument causing the setting to revert to default.
Give some thought to when the instrument produces a new reading, at what rate, and if there is something you need to do to trigger it.
I don't have a good idea on this. You may be able to use NI-MAX to debug it.
You can try to write a test function that uses VISARead in a loop instead of VISAReadWave.
You can try to write a test function that uses viRead in a loop to read one byte at a time to see if it hangs after so many bytes. viRead just calls the VISA driver viRead function so it is the simplest thing you can do.
June 8, 2015 at 12:58 pm - Permalink
IGOR: The instrument outputs 5 values for every measurement (Voltage, Current, Resistance, Time, Status).
I wanted to see if igor could store 50 values in a wave from the 10 datapoints by removing the line in my code that only asks for Voltage.
So, I created a wave with 2 columns and 25 rows and obtained the following:
dataValues[0][0]= {20.0003,9.02712e-05,9.91e+37,0,39948,20.0003,8.97944e-05,9.91e+37,0.0361328,39948,20.0003,9.17167e-05,9.91e+37,0.0722656,39948,20.0003,9.1806e-05,9.91e+37,0.108398,39948,20.0003,9.22084e-05}
dataValues[22][0]= {9.91e+37,0.144531,39948}
dataValues[0][1]= {20.0003,9.26256e-05,9.91e+37,0.180664,39948,20.0003,9.22978e-05,9.91e+37,0.216797,39948,20.0003,9.22978e-05,9.91e+37,0.25293,39948,20.0003,9.26703e-05,9.91e+37,0.289062,39948,20.0003}
dataValues[21][1]= {9.25958e-05,9.91e+37,0.325195,39948}
So, that worked; all the correct values are in proper sequence for the 10 measurements. This eliminated the possibility that igor was having trouble storing more than 10 values in a wave. HOWEVER, I did obtain an error saying: "While executing VISAReadWave, the following error occurred: An invalid index was used to access a wave."
Am I just not sizing my wave correctly?
June 8, 2015 at 03:38 pm - Permalink
This would read 11 numbers, not 11 sets of 5 numbers.
If I understand correctly, you would want to do this:
This will read 5 numbers 11 times.
VISA XOP is not multi-dimensional-aware so it treats this the same as one wave with 50 rows.
June 8, 2015 at 03:54 pm - Permalink
Initially, I was only sending a query for voltage. I could read and store 10 voltage measurements into a wave no problem, but 11 measurements failed. In summary:
- 1 value query for 10 measurements, 10x1 wave SUCCESS
- 1 value query for 10 measurements, 11x1 wave FAIL (igor freezes, presumably b/c index our of range)
- 1 value query for 11 measurements, 11x1 wave FAIL (igor freezes for a little, then fills in last value with a zero)
With the 10 measurements working at least, I tried to query all 5 values from the 10 measurements:
- 5 value query for 10 measurements, 50x1 wave SUCCESS
- 5 value query for 10 measurements, 25x2 wave SUCCESS (although it gives index out of range error)
- 5 value query for 11 measurements, 55x1 wave FAIL (igor freezes for a little, then fills in last 5 values with zeroes)
- 5 value query for 12 measurements, 30x2 wave FAIL (igor DOES NOT freeze, but it fills in last 10 values with zeroes and gives index out of range error)
I am not sure how I ever got it to work with 30 values (I accidentally deleted a copy of the code, arg), but this has to be an igor problem/mistake since the NI-MAX is showing exactly what it should for the same query. You're probably right, it has something to do with the way it is reading the 11th measurement, but I just don't see how it should be any different than the 9th or 10th measurement. I don't want to bother you anymore; I'll keep at it. Thank you very much for your time.
June 8, 2015 at 05:11 pm - Permalink
The code shown below works perfectly. I obtain a wave containing 10 voltage values that I specified in my sweep. I can also specify if I want the 10 corresponding current values as well, in which case I just make my wave size 20 instead of 10; that works too. But, let's just say I am reading these 10 voltage values for simplicity. If I make my TRAC:POIN = 20, and TRIG:COUN = 20, and specify 10 additional voltages to my list, and increase the size of 'datavalues1' = 20, then it crashes, however it runs perfectly if I set 'datavalues1' back to a size of 10 and leave TRAC:POIN and TRIG:COUN = 20..
Igor crashes if:
1.) 'datavlaues1' wave is greater than 10
2.) TRAC:POIN is greater than 20
3.) TRIG:COUN is greater than 20
For some reason, Igor just can't read more than 10 data points. NI MAX shows that all 20 data points are indeed contained in the buffer, but if Igor tries to read beyond 10 of those data points, it either crashes or the additional values show up as zero.
Is there a buffer size or something that I need to edit in Igor? You had mentioned looping my Read function, but I do not know the best way of doing that. Thank you again for your help.
October 16, 2015 at 03:31 pm - Permalink
This is telling VISAReadWave to read 10 values into a 2D wave. Try /N=(10) to make a 1D wave. If you want to read 20, use /N=(20). Don't use /N=(20,1).
Using /N=(10,1) should not cause Igor to crash. It would be helpful if you could create the simplest possible function that demonstrates the crash. This will allow me to focus on the source code that might be responsible for the crash.
October 16, 2015 at 05:10 pm - Permalink
Instead of using:
I simplified it and used:
Here, I measure 12 voltage values with the instrument and store them into the buffer. When I use VISARead in Igor, I obtain this:
+1.000000E-01,+2.000000E-01,+3.000000E-01,+4.000000E-01,+5.000000E-01,+6.000000E-01,+7.000000E-01,+8.000000E-01,+9.000000E-01,+1.000000E+00
Immediately after that, I manually query the buffer using NI MAX and obtain this:
+1.000000E-01,+2.000000E-01,+3.000000E-01,+4.000000E-01,+5.000000E-01,+6.000000E-01,+7.000000E-01,+8.000000E-01,+9.000000E-01,+1.000000E+00,+1.100000E+00,+1.200000E+00
So, the values are in the buffer ready to be read, but igor cannot read in more than the 10 values, only less than 10 values. Also note that Igor does not timeout or give me any errors, it just truncates the buffer after 10 values. Is there a character limit or a delimiter limit?
Thanks again for your help.
October 21, 2015 at 07:56 pm - Permalink
As far as I know, there is no limit to the number of bytes that you can read using VISARead.
I would expect this to read 10 numbers. VISAReadWave attempts to read as many numbers as there are points in the output wave. If you want to read 12 numbers, you need to use /N=(12) with Make.
Also, print V_flag after calling VISAReadWave. This tells you the number of individual numbers read.
Assuming that variableRead is a string variable, this should read until it hits a carriage return or a linefeed. If variableRead is a string variable, then VISARead does not treat the input as numeric text but rather as just a stream of bytes. It does not parse the string. It just reads bytes until it reads a byte that is a terminator.
I don't know what is causing the trouble you are having. To debug it, I would need the instrument.
Here is a test function that does not require any instrument. It works correctly on my machine:
October 21, 2015 at 11:38 pm - Permalink
January 11, 2016 at 02:36 pm - Permalink
Thanks for the update. I'm glad you got it working. I too do not understand why.
January 11, 2016 at 04:23 pm - Permalink