In order to access scan2d object from other IDL program, a user has to make sure that the following environment variable is set before invoking IDL :
setenv EPICS_EXTENSIONS /usr/local/epics/extensions
setenv IDL_STARTUP /usr/local/epics/extensions/bin/$HOST_ARCH/viewer_startup.pro
and make sure including the directory /usr/local/epics/extensions/bin/$HOST_ARCH in his/her IDL search path.
From the unix operating system to access IDL scan2d object class by entering :
idl go_scan2d
The files u_read.pro, and scan2d__define.pro are automatically loaded into IDL 5.0 for user.
For an example to create a 'scan2d' object with variable name as v2, where the 2D catcher data is saved in the file 'junk2.image':
v2 = obj_new('scan2d',file='junk2.image')
To view the image number 135 from the file:
v2->view,135
NAME: scan2d::ASCII PURPOSE: This method allows the user to create a list of ASCII data files based on the user specified list of image numbers. The name convention of each ASCII file will be the image file suffixed with its 4 digit image number. CALLING SEQUENCE: Obj->[scan2d::]ASCII, List, /NOWIN ARGUMENTS: List: List is used to specify the sequence of image files to be generated. It can be a list of short integers which explicitly specify the desired images or it can be string variable. If it is a string, it will be parsed into a list of image number first by this method. The user has to insure that the number entered is valid for normal operation of this method. KEYWORDS: NOWIN: If specified, only the ASCII files will be created but the xdisplayfile window will not be shown. EXAMPLE: Example 1 creates the ASCII data files for the image [10,20,30] from the 'junk2.image', and each file will be displayed automatically. The object v2 need to be defined only if it is not yet defined. v2 = obj_new('scan2d',file='junk2.image') v2->ASCII,[10,20,30] Example 2 creates the ASCII data files for the images 10, 20 to 30, and 40 from the 'junk2.image', and no ASCII file will be displayed. v2->ASCII,'10,20-30,40',/NOWIN MODIFICATION HISTORY: Written by: Ben-chin Cha, Jan 19, 1998. xx-xx-xxxx comment
(See scan2d__define.pro)
NAME: scan2d::DataToText PURPOSE: For the current scan2d object, this method creates its tabulated 2D image data in a disk file and uses the xdisplayfile command to show the contents of the created ASCII file. It will try to create the ASCII file in the following order: try the data directory first, if failed then try the user starting directory, if still failed then try the user home directory. CALLING SEQUENCE: Obj->[scan2d::]DataToText, Data, Px, Py, OUTFILE='outfile', /NOWIN ARGUMENTS: Data: Optional output variable, gives the output image data array. Px: Optional output variable, gives the X positioner vector. Py: Optional output variable, gives the Y positioner vector. KEYWORDS: OUTFILE: If not specified, the default outfile text file name with 'view2d_data.txt' will be used. If OUTFILE=1 is specified, then the outfile name will be generated from the image file name suffixed with 4 digit image number. If OUTFILE='anyname' then the outfile name suffixed with '.txt' will be used by the text file. NOWIN: If specified, the xdisplayfile window will not be shown. EXAMPLE: Following example reads and plots the 135th image from file 'junk2.image' and generates an ASCII outfile with file name 'junk2.image.0135'. The object v2 need to be defined only if it is not yet defined. v2 = obj_new('scan2d',file='junk2.image') v2->View,135 v2->datatotext,/OUTFILE MODIFICATION HISTORY: Written by: Ben-chin Cha, Jan 19, 1998. 05-15-1998 bkc Catch error for openw
(See scan2d__define.pro)
NAME: scan2d::Index PURPOSE: This method explicitly reads in the whole 2D image file and creates the index structure for the image file. It then moves the file pointer at the beginning of the file. This method is automatcally called by the obj_new creation if the file keyword is specified on the object creation. CALLING SEQUENCE: Obj->[scan2d::]Index, Filename ARGUMENTS: FILENAME: Specifies name of the 2D image file (generated by the data catcher) KEYWORDS: None. EXAMPLE: Following example shows how to open and index the 2D image file with name 'junk2.image', and the file pointer is positioned at the beginning of the file. The object v2 need to be defined only if it is not yet defined. v2 = obj_new('scan2d') v2->index, 'junk2.image' The above example is equivalent to the following example. v2 = obj_new('scan2d',file='junk2.image') MODIFICATION HISTORY: Written by: Ben-chin Cha, Jan 19, 1998. xx-xx-xxxx comment
(See scan2d__define.pro)
NAME: scan2d::Open PURPOSE: This method opens the 2D image file according to the data binary type. It supports both native binary type and XDR binary type. This method is automatically called by the object creation method. CALLING SEQUENCE: Obj->[scan2d::]Open, Filename [,Wid] ARGUMENTS: FILENAME: Specifies the 2D image file (generated by the data catcher) WID: Optional input, specifies the input droplist widget ID to reflect the binary TYPE in an existing widget program KEYWORDS: None. EXAMPLE: Following example shows how to explicitly open the 2D image file with name 'junk2.image', and the file pointer is positioned at the beginning of the file. The object v2 need to be defined only if it is not yet defined. v2 = obj_new('scan2d') v2->open, 'junk2.image' MODIFICATION HISTORY: Written by: Ben-chin Cha, Jan 19, 1998. xx-xx-xxxx comment
(See scan2d__define.pro)
NAME: scan2d::panImage PURPOSE: This method pops up a new PanImage window for a given 2D scan #. If the 2D scan # is not specified, then the 2D scanno # will be calculated from the current 2D image sequence number. CALLING SEQUENCE: Obj->[scan2d::]panImage [,Scanno] [,Factor] ARGUMENTS: Scanno: Specifies the 2D scan # Factor: Optional input, to specify the panImage window ratio factor KEYWORDS: None. RESTRICTION: For a given 2D scan, before calling scan2D::panImage the scan2D::read should have been called for one of the detectors in order to figure out the dimensions of the image objects. EXAMPLE: Following example shows how to get the panImage of all detectors for 2D scan #2, #3, and # 5 from the 2D image file 'junk2.image'. The object v2 need to be defined only if it is not yet defined. v2 = obj_new('scan2d',file='junk2.image') v2->read v2->panImage,2 v2->panImage,3 v2->panImage,5 MODIFICATION HISTORY: Written by: Ben-chin Cha, Nov 19, 1998. xx-xx-xxxx comment
(See scan2d__define.pro)
NAME: scan2d::Point_lun PURPOSE: The method moves the 2D image file pointer to the end of the specified record. CALLING SEQUENCE: Obj->[scan2d::]Point_lun, SEQNO ARGUMENTS: SEQNO: Specifies the zero based image sequence number. KEYWORDS: None. EXAMPLE: Following example moves the file pointer to the end of the 10th record of the 2D image file 'junk2.image'. The object v2 need to be defined only if it is not yet defined. v2 = obj_new('scan2d',file='junk2.image') v2->point_lun,10 MODIFICATION HISTORY: Written by: Ben-chin Cha, Jan 19, 1998. 05-15-1998 bkc Add message dialog if illegal number entered
(See scan2d__define.pro)
NAME: scan2d::Print PURPOSE: This method prints the current key variables for the object structure. It prints the starting and data directory, image filename, total # of 2D scan, totol # of images, current 2D Scan #, detector #, and image seq # at current image pointer, and the image seq array to corresponding to detector 1. CALLING SEQUENCE: Obj->[scan2d::]Print ARGUMENTS: None. KEYWORDS: None. EXAMPLE: Following example shows current key variables of the object v2. v2->print MODIFICATION HISTORY: Written by: Ben-chin Cha, Jan 19, 1998. xx-xx-xxxx comment
(See scan2d__define.pro)
NAME: scan2d::Read PURPOSE: This method reads in one set of image record from the current file pointer. CALLING SEQUENCE: Obj->[scan2d::]Read, /VIEW, WIDTH=width, HEIGHT=height, $ DETECTOR=detector, SCANNO_2D=scanno_2d, X=x, Y=y, IM=im ARGUMENTS: None. KEYWORDS: VIEW: If specified, the read in 2D image will also be displayed on the plot window. X: If specified, it returns the X vector values. Y: If specified, it returns the Y vector values. IM: If specified, it returns the 2D IM array values. WIDTH: It specified, it returns the X vector size. HEIGHT: It specified, it returns the Y vector size. SCANNO_2D:If specified, it returns the corresponding 2D scan number. DETECTOR: If specified, it returns the detector number for the image. EXAMPLE: Following example reads the 136th image from the input image file and also plot the 2D image. The object v2 need to be defined only if it is not yet defined. v2 = obj_new('scan2d',file='junk2.image') v2->point_lun,135 v2->read,/view MODIFICATION HISTORY: Written by: Ben-chin Cha, Jan 19, 1998. xx-xx-xxxx comment
(See scan2d__define.pro)
NAME: scan2d::Save PURPOSE: This method allows the user read the next image record and save the data to a save file. The saved file can be restored by the restore command. Two type of variables can be saved by this command: either save the whole object or just save the x,y,im arrays. The data saved will be in XDR format. CALLING SEQUENCE: Obj->[scan2d::]Save, No, FILE=file, /VERBOSE, /OBJECT ARGUMENTS: No Specifies the desired sequence number of the image record to be read. If not specified then the next record is assumed. KEYWORDS: FILE: Specifies the save file name, it defaults to 'idlsave.dat'. VERBOSE: If specified, the verbose mode is assumed, the variables saved will be listed. OBJECT: If specified, the complete data object is saved. Otherwise only the NO, X, Y, IM variables are saved for the record. EXAMPLE: Example 1 - Saves the X,Y,IM arrays for the 135th record in 'junk2.image.s0135', also list the variables saved. The object v2 need to be defined only if it is not yet defined. v2 = obj_new('scan2d',file='junk2.image') v2->save,135,file='junk2.image.s0135',/verbose Example 2 - Saves all the variables for the 135th record in 'junk2.image.s0135', also list the variables saved v2->save,135,file='junk2.image.s0135',/verbose,/object MODIFICATION HISTORY: Written by: Ben-chin Cha, Jan 19, 1998. xx-xx-xxxx comment
(See scan2d__define.pro)
NAME: scan2d::Valid PURPOSE: This method checks whether the input image no is valid. CALLING SEQUENCE: Obj->[scan2d::]Valid,No,CODE=code ARGUMENTS: No Specifies the image record number. KEYWORDS: CODE: Returns the return code, 0 if valid, -1 if invalid. EXAMPLE: Following example checks whether image number 130 is a valid request for the 'junk2.image' file The object v2 need to be defined only if it is not yet defined. v2 = obj_new('scan2d',file='junk2.image') v2->Valid,130,code=code MODIFICATION HISTORY: Written by: Ben-chin Cha, Jan 19, 1998. xx-xx-xxxx comment
(See scan2d__define.pro)
NAME: scan2d::View PURPOSE: This method lets the user view any valid 2D image from the 2D data catcher image file. It also automatically pops up the flexible 2D plot package, it allows the user view 2D image in TV, SURFACE, CONTOUR, and SHADE_SURF and generated the printer copy from the PS file, idl.ps, if desired. CALLING SEQUENCE: Obj->[scan2d::]View, No, SCANNO=scanno, DETECTOR=detector, NOREAD=noread ARGUMENTS: No Specifies the sequence number of the image record. KEYWORDS: SCANNO: It specifies the 2D scan number. If specified,it ignore the 'No' specification. Valid SCANNO range: [1 - self.scanno_2d_last] DETECTOR: It specifies the desired detector number from the 2D scan. If not specified, and SCANNO is given, detector 1 is assumed. NOREAD: If specified, no reading from the file pointer is done, only plot the current object is performed. NOPLOT: If specified, no 2D flexible plotting package available. EXAMPLE: Example 1 reads and plots the 135th image from the 'junk2.image' The object v2 need to be defined only if it is not yet defined. v2 = obj_new('scan2d',file='junk2.image') v2->View,135 Example 2 reads and plots the image of detector 7 of the 21th 2D scan from the 'junk2.image' file v2->View,scanno=21,detector=7 MODIFICATION HISTORY: Written by: Ben-chin Cha, Jan 19, 1998. 12-16-1998 Add flexible 2D TV, SURFACE, CONTOUR,SHADE_SURF plot option
(See scan2d__define.pro)