Torque Control Using Analog Feedback C/C++ Code
The following example code is not necessarily complete, and may not compile if copied exactly. Refer to the examples folder on the NI-Motion CD for files that are complete and compile as is.
// Main function void main(void) { u8 boardID; // Board identification number u8 axis; // Axis number u16 csr = 0; // Communication status register u16 axisStatus; // Axis status u16 moveComplete; // Variables for modal error handling u16 commandID; // The commandID of the function u16 resourceID; // The resource ID i32 errorCode; // Error code /////////////////////////////// // Set the board ID boardID= 1; // Set the axis number axis = 1; //////////////////////////////// //----------------------------------------------------------- // Is is assumed that the axis being moved has an ADC channel // mapped as its primary feedback. Position is treated as binary // volts. Hence velocity is loaded in binary volts/sec and // acceleration as binary volts/sec^2. //----------------------------------------------------------- // Set the velocity for the move (in binary volts/sec) err = flex_load_velocity(boardID, axis, 10000, 0xFF); CheckError; // Set the acceleration for the move (in binary volts/sec^2) err = flex_load_acceleration(boardID, axis, NIMC_ACCELERATION, 100000, 0xFF); CheckError; // Set the deceleration for the move (in binary volts/sec^2) err = flex_load_acceleration(boardID, axis, NIMC_DECELERATION, 100000, 0xFF); CheckError; // Set the jerk - s-curve time (in sample periods) err = flex_load_scurve_time(boardID, axis, 1000, 0xFF); CheckError; // Set the operation mode err = flex_set_op_mode (boardID, axis, NIMC_ABSOLUTE_POSITION); CheckError; // Load Position corresponding to the voltage which you want // the motor to maintain (2047 ~ 5V in this example) err = flex_load_target_pos (boardID, axis, 2047, 0xFF); CheckError; // Start the move err = flex_start(boardID, axis, 0); CheckError; do { axisStatus = 0; // Check the move complete status err = flex_check_move_complete_status(boardID, axis, 0, &moveComplete); CheckError; // Check the following error/axis off status for axis 1 err = flex_read_axis_status_rtn(boardID, axis, &axisStatus); CheckError; // Read the communication status register and check the modal errors err = flex_read_csr_rtn(boardID, &csr); CheckError; // Check the modal errors if (csr & NIMC_MODAL_ERROR_MSG) { err = csr & NIMC_MODAL_ERROR_MSG; CheckError; } }while (!moveComplete && !(axisStatus & NIMC_FOLLOWING_ERROR_BIT) && !(axisStatus & NIMC_AXIS_OFF_BIT)); // Exit on move complete/following error/axis off return; // Exit the Application ///////////////////////////////////////////////////////////////////////// // Error Handling // nimcHandleError; //NIMCCATCHTHIS: // Check to see if there were any Modal Errors if (csr & NIMC_MODAL_ERROR_MSG){ do{ // Get the command ID, resource and the error code of the modal // error from the error stack on the board flex_read_error_msg_rtn(boardID,&commandID,&resourceID,&errorCode); nimcDisplayError(errorCode,commandID,resourceID); // Read the Communication Status Register flex_read_csr_rtn(boardID,&csr); }while(csr & NIMC_MODAL_ERROR_MSG); } else // Display regular error nimcDisplayError(err,0,0); return; // Exit the Application }