NAME

Lab::XPRESS::Sweep::Motor - stepper motor sweep

.

SYNOPSIS

use Lab::XPRESS::hub;
my $hub = new Lab::XPRESS::hub();


my $stepper = $hub->Instrument('PDPD11042', 
	{
	connection_type => 'VISA_RS232',
	gpib_address => 2
	});

my $sweep_motor = $hub->Sweep('Motor',
	{
	instrument => $stepper,
	points => [-10,10],
	rate => [1.98,1],
	mode => 'continuous',		
	interval => 1,
	backsweep => 1 
	});

.

DESCRIPTION

Parent: Lab::XPRESS::Sweep::Sweep

The Lab::XPRESS::Sweep::Motor class implements a module for stepper motor sweeps in the Lab::XPRESS::Sweep framework.

.

CONSTRUCTOR

my $sweep_motor = $hub->Sweep('Motor',
	{
	instrument => $stepper,
	points => [-10,10],
	rate => [1.98,1],
	mode => 'continuous',		
	interval => 1,
	backsweep => 1 
	});

Instantiates a new stepper motor sweep

.

SWEEP PARAMETERS

instrument [Lab::Instrument] (mandatory)

Instrument, conducting the sweep. Must be of type Lab:Instrument. Allowed instruments: Lab::Instrument::PD11042, Lab::Instrument::ProStep4

.

mode [string] (default = 'continuous' | 'step' | 'list')

continuous: perform a continuous stepper motor sweep. Measurements will be performed constantly at the time-interval defined in interval.

step: measurements will be performed at discrete values between start and end points defined in parameter points, seperated by a step defined in parameter stepwidth

list: measurements will be performed at a list of values defined in parameter points

.

points [float array] (mandatory)

array of values (in deg) that defines the characteristic points of the sweep. First value is appraoched before measurement begins.

Case mode => 'continuous' : List of at least 2 values, that define start and end point of the sweep or a sequence of consecutive sweep-sections (e.g. if changing the sweep-rate for different sections or reversing the sweep direction). points => [0, 180] # Start: 0 / Stop: 180

points => [0, 90, 180, 360]

points => [0, -90, 90]

Case mode => 'step' : Same as in 'continuous' but stepper motor will be swept in stop and go mode. I.e. stepper motor approaches values between start and stop at the interval defined in 'stepwidth'. A measurement is performed, when the motor is idle.

Case mode => 'list' : Array of values, with minimum length 1, that are approached in sequence to perform a measurment.

.

rate [float array] (mandatory if not defined duration)

array of rates, at which the stepper motor is swept (deg / min). Has to be of length 1 or greater (Maximum length: length of points-array). The first value defines the rate to approach the starting point. The following values define the rates to approach the values defined by the points-array. If the number of values in the rates-array is less than the length of the points-array, the last defined rate will be used for the remaining sweep sections.

points => [-90, 0, 90, 180],
rates => [1, 0.5, 0.2]

rate to approach -90 deg (the starting point): 1 deg/min 
rate to approach 0 deg  : 0.5 deg/min 
rate to approach 90 deg  : 0.2 deg/min 
rate to approach 180 deg   : 0.2 deg/min (last defined rate)

.

duration [float array] (mandatory if not defined rate)

can be used instead of 'rate'. Attention: Use only the 'duration' or the 'rate' parameter. Using both will cause an Error!

The first value defines the duration to approach the starting point. The second value defines the duration to approach the value defined by the second value of the points-array. ... If the number of values in the duration-array is less than the length of the points-array, last defined duration will be used for the remaining sweep sections.

.

stepwidth [float array]

This parameter is relevant only if mode = 'step' has been selected. Stepwidth has to be an array of length '1' or greater. The values define the width for each step within the corresponding sweep sequence. If the length of the defined sweep sequence devided by the stepwidth is not an integer number, the last step will be smaller in order to reach the defined points-value.

points = [0, 90, 180]
stepwidth = [10, 25]

==> steps: 0, 10, 20, 30, 40, 50, 60, 70, 80, 90, 115, 140, 165, 180

.

number_of_points [int array]

can be used instead of 'stepwidth'. Attention: Use only the 'number_of_points' or the 'stepwidth' parameter. Using both will cause an Error! This parameter is relevant only if mode = 'step' has been selected. Number_of_points has to be an array of length '1' or greater. The values defines the number of steps within the corresponding sweep sequence.

points = [0, 90, 180]
number_of_points = [5, 2]

==> steps: 0, 18, 36, 54, 72, 90, 135, 180

.

interval [float] (default = 1)

interval in seconds for taking measurement points. Only relevant in mode 'continuous'.

.

backsweep [int] (default = 0 | 1 | 2)

0 : no backsweep (default) 1 : a backsweep will be performed 2 : no backsweep performed automatically, but sweep sequence will be reverted every second time the sweep is started (relevant eg. if sweep operates as a slave. This way the sweep sequence is reverted at every second step of the master)

.

id [string] (default = 'Motor_sweep')

Just an ID.

.

filename_extention [string] (default = 'PHI=')

Defines a postfix, that will be appended to the filenames if necessary.

.

delay_before_loop [int] (default = 0)

defines the time in seconds to wait after the starting point has been reached.

.

delay_in_loop [int] (default = 0)

This parameter is relevant only if mode = 'step' or 'list' has been selected. Defines the time in seconds to wait after the value for the next step has been reached.

.

delay_after_loop [int] (default = 0)

Defines the time in seconds to wait after the sweep has been finished. This delay will be executed before an optional backsweep or optional repetitions of the sweep.

.

CAVEATS/BUGS

probably none

.

SEE ALSO

Lab::XPRESS::Sweep

.

AUTHOR/COPYRIGHT

Christian Butschkow and Stefan Geißler

This library is free software; you can redistribute it and/or modify it under the same terms as Perl itself.

.