You can not select more than 25 topics
			Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
		
		
		
		
		
			
		
			
				
					
					
						
							194 lines
						
					
					
						
							6.9 KiB
						
					
					
				
			
		
		
		
			
			
			
				
					
				
				
					
				
			
		
		
	
	
							194 lines
						
					
					
						
							6.9 KiB
						
					
					
				| /* {{[PH] | |
| **************************************************************************** | |
|  Project:  FRI | |
|  | |
|   This material is the exclusive property of KUKA Roboter GmbH  | |
|   and must be returned to KUKA Roboter GmbH immediately upon  | |
|   request.  This material and the information illustrated or  | |
|   contained herein may not be used, reproduced, stored in a  | |
|   retrieval system, or transmitted in whole or in part in any  | |
|   way - electronic, mechanical, photocopying, recording, or  | |
|   otherwise, without the prior written consent of KUKA Roboter GmbH.   | |
|    | |
|                  All Rights Reserved | |
|                  Copyright (C)  2009 | |
|                   KUKA Roboter GmbH | |
|                   Augsburg, Germany | |
|    | |
| [PH]}} | |
| */ | |
| 
 | |
| /* | |
| {{[FH] | |
| **************************************************************************** | |
|   friFirstApp.cpp | |
|         | |
|       NOTE: This sample, as the corresponding FRI (Fast Research inteface) is subject to radical change | |
| 	   | |
|        | |
| [FH]}} | |
| */  | |
| /** | |
| 	\defgroup friRemoteLib | |
| 	\brief Library for FRI (FastResearchInterface)  | |
| */ | |
| /* @{ */ | |
| 
 | |
| /**  | |
|  \author (Guenter Schreiber) | |
| \file | |
| \brief Remote class for handshaking/dealing with udp datastructures | |
|  | |
|   This code is most important to understand the concepts behind data handshake | |
| */ | |
| #ifndef FRIFRIREMOTE_H | |
| #define FRIFRIREMOTE_H | |
|  | |
| 
 | |
| #include "friudp.h" | |
|  | |
| 
 | |
| 
 | |
| 
 | |
| /** | |
| 	@author Günter Schreiber <guenter@jacobus> | |
| */ | |
| 
 | |
| class friRemote | |
| { | |
| public: | |
| 	friRemote(int port = FRI_DEFAULT_SERVER_PORT, char * hintToRemoteHost=NULL); | |
| 	~friRemote(); | |
| 
 | |
| 	/** Data Exchanger -- normally update within access routine implicitely  | |
| 	send commands based on last datagram and after waits on new measurement | |
| 	calls doSendData() and doReceiveData(); | |
| 	... */ | |
| 	int doDataExchange(); | |
| 	/** Receives data while calling friUdp::Recv() | |
| 	The call will block.. | |
| 	*/ | |
| 	int doReceiveData(); | |
| 	/** Sends the data */ | |
| 	int doSendData(); | |
| 		/* @{ */ | |
| 	/** automatically do data exchange, if not otherwise specified  | |
| 	if flagDataExchange is set to false, call doDataExchange()  | |
| 	or doReceiveData()/doSendData() on your own | |
| 	*/ | |
| 	int doPositionControl(float newJntPosition[LBR_MNJ], bool flagDataExchange=true); | |
| 
 | |
| 	/** automatically do data exchange, if not otherwise specified  | |
| 	if flagDataExchange is set to false, call doDataExchange()  | |
| 	or doReceiveData()/doSendData() on your own | |
| 	IN: newJntPosition   - joint positions | |
| 	newJntStiff      - joint stiffness (Spring factor) | |
| 	newJntDamp       - joint damping   (Damping factor) | |
| 	newJntAddTorque  - additional torque  | |
|  | |
| 	Note: If any of the pointers (newJntPosition, newJntStiff, newJntDamp, newJntAddTorque) is NULL, the  | |
| 	value is ignored -> the respective  cmd.cmd.cmdFlags field is set properly | |
| 	Note: It is possible to change cmd.cmd.cmdFlags in monitor mode only !! | |
| 	*/ | |
| 	int doJntImpedanceControl(const float newJntPosition[LBR_MNJ], const float newJntStiff[LBR_MNJ] = NULL, const float newJntDamp[LBR_MNJ]=NULL, const float newJntAddTorque[LBR_MNJ]=NULL,bool flagDataExchange=true); | |
| 
 | |
| 
 | |
| 	/** automatically do data exchange, if not otherwise specified  | |
| 	if flagDataExchange is set to false, call doDataExchange()  | |
| 	or doReceiveData()/doSendData() on your own | |
| 	IN: newJntPosition   - joint positions | |
| 	newJntStiff      - joint stiffness (Spring factor) | |
| 	newJntDamp       - joint damping   (Damping factor) | |
| 	newJntAddTorque  - additional torque  | |
|  | |
| 	Note: If any of the pointers (newJntPosition, newJntStiff, newJntDamp, newJntAddTorque) is NULL, the  | |
| 	value is ignored -> the respective  cmd.cmd.cmdFlags field is set properly | |
| 	Note: It is possible to change cmd.cmd.cmdFlags in monitor mode only !! | |
| 	*/ | |
| 	int doCartesianImpedanceControl(const float newCartPosition[FRI_CART_FRM_DIM],  | |
| 		const float newCartStiff[FRI_CART_VEC]=NULL,  | |
| 		const float newCartDamp[FRI_CART_VEC]=NULL,  | |
| 		const float newAddTcpFT[FRI_CART_VEC]=NULL, | |
| 		const float newJntNullspace[LBR_MNJ]=NULL,  bool flagDataExchange=true); | |
| 		/* @} */ | |
| 
 | |
| 	/** measured Cartesian frame (in m) | |
| 	KRL: $POS_ACT_MSR | |
| 	Reference: Base and tool are specified by $stiffness.base, $stiffness.tool  | |
| 	*/ | |
| 	float * getMsrCartPosition() { return msr.data.msrCartPos; } | |
| 	/** commanded Cartesian frame (in m, before FRI)  | |
| 	KRL: $POS_ACT_CMD | |
| 	Reference: Base and tool are specified by $stiffness.base, $stiffness.tool  | |
| 	*/ | |
| 	float * getMsrCmdCartPosition() { return msr.data.cmdCartPos; } | |
| 
 | |
| 	/** commanded Cartesian frame (in m, due to FRI) */ | |
| 	float * getMsrCmdCartPosFriOffset() { return msr.data.cmdCartPosFriOffset; } | |
| 
 | |
| 	/** Access to inner buffers for further manipulation */ | |
| 	tFriMsrData & getMsrBuf() { return msr;} | |
| 	tFriCmdData & getCmdBuf() { return cmd;} | |
| 	/* @{ */ | |
| 	/** interpretational access routines */ | |
| 	FRI_STATE getState()      { return (FRI_STATE)msr.intf.state;   } | |
| 	FRI_QUALITY getQuality()  { return (FRI_QUALITY)msr.intf.quality; } | |
| 	FRI_CTRL getCurrentControlScheme (){ return (FRI_CTRL)msr.robot.control; } | |
| 
 | |
| 	bool isPowerOn() { return msr.robot.power!=0; } | |
| 	/* @} */ | |
| 
 | |
| 	/* @{ */ | |
| 	/** Important value for superposition - and during poweroff stages, to become command mode */ | |
| 	float * getMsrCmdJntPosition() { return msr.data.cmdJntPos; } | |
| 	/** returns the offset, which is commanded by FRI Remote side  | |
| 	*  Complete desired position inside LBR Kernel is the sum of cmdJntPos and cmdJntPosFriOffset */ | |
| 	float * getMsrCmdJntPositionOffset() { return msr.data.cmdJntPosFriOffset; } | |
| 
 | |
| 	void getCurrentCmdJntPosition( float jntVec[LBR_MNJ] ) { for ( int i = 0; i < LBR_MNJ; i++) jntVec[i]= msr.data.cmdJntPos[i]+msr.data.cmdJntPosFriOffset[i];} | |
| 	/** Current measured jnt position of the robot */ | |
| 	float * getMsrMsrJntPosition() { return msr.data.msrJntPos; } | |
| 	float * getMsrEstExtJntTrq() { return msr.data.estExtJntTrq; } | |
| 	float * getMsrJntTrq() { return msr.data.msrJntTrq; } | |
| 		/* @} */ | |
| 
 | |
| 	float getSampleTime() { return msr.intf.desiredCmdSampleTime; } | |
| 	int getSequenceCount() { return seqCount; } | |
| 
 | |
| 	/* @{ */ | |
| 	/** KRL Interaction -- Corresponds to $FRI_TO_REA */ | |
| 	float getFrmKRLReal(int index) { return msr.krl.realData[index]; } | |
| 	/** KRL Interaction -- Corresponds to $FRI_FRM_REA */ | |
| 	void  setToKRLReal(int index, float val) { cmd.krl.realData[index]=val; } | |
| 		/** KRL Interaction -- Corresponds to $FRI_TO_INT */ | |
| 	int   getFrmKRLInt(int index) { return msr.krl.intData[index]; } | |
| 		/** KRL Interaction -- Corresponds to $FRI_FRM_INT */ | |
| 	void  setToKRLInt(int index, int val) { cmd.krl.intData[index]=val; } | |
| 		/** KRL Interaction -- Corresponds to $FRI_TO_BOOL */ | |
| 	bool  getFrmKRLBool(int index) { return ((msr.krl.boolData & (1<<index)) != 0);} | |
| 		/** KRL Interaction -- Corresponds to $FRI_FRM_BOOL */ | |
| 	fri_uint16_t getFrmKRLBool() { return msr.krl.boolData; } | |
| 		/** KRL Interaction -- Corresponds to $FRI_FRM_BOOL */ | |
| 	void  setToKRLBool(int index, bool val)  | |
| 	{ if ( val) { cmd.krl.boolData |= (1<<index);}  | |
| 	else {cmd.krl.boolData &= (~(1<<index));}} | |
| 	void setToKRLBool(fri_uint16_t val) {   cmd.krl.boolData = val; } | |
| 	/* @} */ | |
| 	/** Get Jacobian Matrix | |
| 	*/ | |
| 	float * getJacobian() { return msr.data.jacobian; } | |
| 	float * getFTTcp() {return msr.data.estExtTcpFT;} | |
| 
 | |
| protected: | |
| 	tFriMsrData msr; | |
| 	tFriCmdData cmd; | |
| private: | |
| 	friUdp remote; | |
| 	int seqCount; | |
| }; | |
| 
 | |
| 
 | |
| 
 | |
| 
 | |
| #endif | |
| /* @} */
 |