Пример #1
0
void Camera::lookAt(glm::vec3 position) {
    assert(position != _position);
    glm::vec3 direction = glm::normalize(position - _position);
    _verticalAngle = RadiansToDegrees(asinf(-direction.y));
    _horizontalAngle = -RadiansToDegrees(atan2f(-direction.x, -direction.z));
    normalizeAngles();
}
Пример #2
0
void Camera::lookAt()
{
	assert(m_target != m_pos);
	glm::vec3 direction = glm::normalize(m_target - m_pos);
	m_phi = radToDeg(asinf(-direction.y));
	m_theta = -radToDeg(atan2f(-direction.x, -direction.z));
	normalizeAngles();
}
Пример #3
0
void Camera::lookAt(Vec3 position)
{
	if (position == mPosition)
	{
		std::cout << "MEGA ERROR: You are trying to look at your origin" << std::endl;
		return;
	}

	Vec3 direction = glm::normalize(position - mPosition);
	mVerticalAngle = radToDeg(asinf(-direction.y));
	mHorizontalAngle = -radToDeg(atan2f(-direction.x, -direction.z));
	normalizeAngles();
}
    void JacoTrajectoryActionServer::actionCallback(const control_msgs::FollowJointTrajectoryGoalConstPtr &goal) {
        try {
            if (arm_comm_.isStopped()) {
                ROS_ERROR_STREAM("Could not complete joint angle action because the arm is 'stopped'.");
                action_server_.setAborted();
                return;
            }

            // Clear all previous trajectories and points
            arm_comm_.initTrajectory();

            trajectory_msgs::JointTrajectoryPoint goal_waypoint =
                    goal->trajectory.points[goal->trajectory.points.size() - 1];

            trajectory_msgs::JointTrajectoryPoint start_waypoint =
                    goal->trajectory.points[0];

            JacoAngles current_joint_angles, goal_joint_angles, start_joint_angles;
            goal_joint_angles.Actuator1 = goal_waypoint.positions[0] * (180 / PI);
            goal_joint_angles.Actuator2 = goal_waypoint.positions[1] * (180 / PI);
            goal_joint_angles.Actuator3 = goal_waypoint.positions[2] * (180 / PI);
            goal_joint_angles.Actuator4 = goal_waypoint.positions[3] * (180 / PI);
            goal_joint_angles.Actuator5 = goal_waypoint.positions[4] * (180 / PI);
            goal_joint_angles.Actuator6 = goal_waypoint.positions[5] * (180 / PI);
            convertDHAnglesToPhysical(goal_joint_angles);
            normalizeAngles(goal_joint_angles);

            start_joint_angles.Actuator1 = start_waypoint.positions[0] * (180 / PI);
            start_joint_angles.Actuator2 = start_waypoint.positions[1] * (180 / PI);
            start_joint_angles.Actuator3 = start_waypoint.positions[2] * (180 / PI);
            start_joint_angles.Actuator4 = start_waypoint.positions[3] * (180 / PI);
            start_joint_angles.Actuator5 = start_waypoint.positions[4] * (180 / PI);
            start_joint_angles.Actuator6 = start_waypoint.positions[5] * (180 / PI);
            convertDHAnglesToPhysical(start_joint_angles);
            normalizeAngles(start_joint_angles);

            ///////////////////////////////////
            //Sanity Check that arm is actually starting from the first waypoint in the trajectory
            ///////////////////////////////////
            arm_comm_.getJointAngles(current_joint_angles);
            normalizeAngles(current_joint_angles);
            AngularInfo error = computeError(start_joint_angles, current_joint_angles);
            if (std::abs(error.Actuator1) > MAX_ERROR_TOLERANCE) {
                ROS_ERROR_STREAM("Way to large of error in JacoTrajectoryActionServer actuator 1 before even starting, setting to aborted");
                action_server_.setAborted();
                ROS_INFO_STREAM("Leaving: JacoTrajectoryActionServer::actionCallback\n");
                return;
            }
            if (std::abs(error.Actuator2) > MAX_ERROR_TOLERANCE) {
                ROS_ERROR_STREAM("Way to large of error in JacoTrajectoryActionServer actuator 2 before even starting, setting to aborted");
                action_server_.setAborted();
                ROS_INFO_STREAM("Leaving: JacoTrajectoryActionServer::actionCallback\n");
                return;
            }
            if (std::abs(error.Actuator3) > MAX_ERROR_TOLERANCE) {
                ROS_ERROR_STREAM("Way to large of error in JacoTrajectoryActionServer actuator 3 before even starting, setting to aborted");
                action_server_.setAborted();
                ROS_INFO_STREAM("Leaving: JacoTrajectoryActionServer::actionCallback\n");
                return;
            }
            if (std::abs(error.Actuator4) > MAX_ERROR_TOLERANCE) {
                ROS_ERROR_STREAM("Way to large of error in JacoTrajectoryActionServer actuator 4 before even starting, setting to aborted");
                action_server_.setAborted();
                ROS_INFO_STREAM("Leaving: JacoTrajectoryActionServer::actionCallback\n");
                return;
            }
            if (std::abs(error.Actuator5) > MAX_ERROR_TOLERANCE) {
                ROS_ERROR_STREAM("Way to large of error in JacoTrajectoryActionServer actuator 5 before even starting, setting to aborted");
                action_server_.setAborted();
                return;
            }
            if (std::abs(error.Actuator6) > MAX_ERROR_TOLERANCE) {
                ROS_ERROR_STREAM("Way to large of error in JacoTrajectoryActionServer actuator 6 before even starting, setting to aborted");
                action_server_.setAborted();
                ROS_INFO_STREAM("Leaving: JacoTrajectoryActionServer::actionCallback\n");
                return;
            }

            ros::Time start_time = ros::Time::now();
            bool stop = false;
            bool read_joint_angles = false;
            for (unsigned int i = 0; i < goal->trajectory.points.size(); i++) {

                // Get the waypoint to be reached
                trajectory_msgs::JointTrajectoryPoint waypoint =
                        goal->trajectory.points[i];

                // Initialize a trajectory point which we will be constantly
                // feeding to the robot until the waypoint time's up or until
                // we are in the final configuration.
                TrajectoryPoint point;
                point.InitStruct();
                memset(&point, 0, sizeof (point));

                // The trajectory consists of angular velocity waypoints
                point.Position.Type = ANGULAR_VELOCITY;
                
                // Set up the trajectory point with waypoint values converted
                // from [rad/s] to [deg/s]
                point.Position.Actuators.Actuator1 = -waypoint.velocities[0] * (180 / PI);
                point.Position.Actuators.Actuator2 = +waypoint.velocities[1] * (180 / PI);
                point.Position.Actuators.Actuator3 = -waypoint.velocities[2] * (180 / PI);
                point.Position.Actuators.Actuator4 = -waypoint.velocities[3] * (180 / PI);
                point.Position.Actuators.Actuator5 = -waypoint.velocities[4] * (180 / PI);
                point.Position.Actuators.Actuator6 = -waypoint.velocities[5] * (180 / PI);

                JacoAngles current_waypoint_angles;
                current_waypoint_angles.Actuator1 = waypoint.positions[0] * (180 / PI);
                current_waypoint_angles.Actuator2 = waypoint.positions[1] * (180 / PI);
                current_waypoint_angles.Actuator3 = waypoint.positions[2] * (180 / PI);
                current_waypoint_angles.Actuator4 = waypoint.positions[3] * (180 / PI);
                current_waypoint_angles.Actuator5 = waypoint.positions[4] * (180 / PI);
                current_waypoint_angles.Actuator6 = waypoint.positions[5] * (180 / PI);
                convertDHAnglesToPhysical(current_waypoint_angles);
                normalizeAngles(current_waypoint_angles);

                read_joint_angles = false;
                while(!read_joint_angles){
                    try{
                        arm_comm_.getJointAngles(current_joint_angles);
                        read_joint_angles = true;
                    } catch (const std::exception& e) {
                        ROS_ERROR_STREAM(e.what());
                        ROS_ERROR_STREAM("Carrying on anyway!");
                    }
                }

                normalizeAngles(current_joint_angles);
                error = computeError(current_waypoint_angles, current_joint_angles);

                stop = false;
                checkCurrentWayPointError(error.Actuator1, stop);
                checkCurrentWayPointError(error.Actuator2, stop);
                checkCurrentWayPointError(error.Actuator3, stop);
                checkCurrentWayPointError(error.Actuator4, stop);
                checkCurrentWayPointError(error.Actuator5, stop);
                checkCurrentWayPointError(error.Actuator6, stop);
                if(stop)
                {
                    ROS_ERROR_STREAM("Inside Open Loop Velocity Controller: Way to large of error in JacoTrajectoryActionServer actuator setting to aborted");
                    ROS_ERROR_STREAM("error.Actuator1: " << error.Actuator1 << std::endl);
                    ROS_ERROR_STREAM("error.Actuator2: " << error.Actuator2 << std::endl);
                    ROS_ERROR_STREAM("error.Actuator3: " << error.Actuator3 << std::endl);
                    ROS_ERROR_STREAM("error.Actuator4: " << error.Actuator4 << std::endl);
                    ROS_ERROR_STREAM("error.Actuator5: " << error.Actuator5 << std::endl);
                    ROS_ERROR_STREAM("error.Actuator6: " << error.Actuator6 << std::endl);
                    action_server_.setAborted();
                    return;
                }

                ros::Rate r(100);   // The loop below will run at 100Hz
                
                while ((waypoint.time_from_start >= ros::Time::now() - start_time)) {
                    ros::spinOnce();

                    // If preempted, stop the motion, enable the arm again and
                    // send a notification of preemption
                    if (action_server_.isPreemptRequested() || !ros::ok()) {
                        arm_comm_.stopAPI();
                        arm_comm_.startAPI();
                        action_server_.setPreempted();
                        return;
                    } else if (arm_comm_.isStopped()) {
                        action_server_.setAborted();
                        return;
                    }

                    // Get the current real angles and normalize them for comparing
                    // with the target and adjusting the execution
//                    arm_comm_.getJointAngles(current_joint_angles);
//                    normalizeAngles(current_joint_angles);

                    // Adjust actuator velocities accordingly
                    arm_comm_.addTrajectoryPoint(point);

                    // Ensures executing at 100Hz
                    r.sleep();
                }
            }

            stop = false;

            ros::Rate r(100); // The loop below will run at 100Hz (every 10ms)
            
            // This loop finalizes the movement by checking angular distance
            // of joints from the desired configuration. Instead of moving
            // to the last waypoint, we move and check each joint separately
            // to ensure we are at the right position.
            bool reached_goal = false;
            while (!reached_goal) {
                // Get the current real angles and normalize them for comparing
                // with the target and adjusting the execution
                arm_comm_.getJointAngles(current_joint_angles);
                normalizeAngles(current_joint_angles);
                AngularInfo error = computeError(goal_joint_angles, current_joint_angles);
                
                // Initialize a trajectory point which we will be constantly
                // feeding to the robot untilwe are in the final configuration.
                TrajectoryPoint point;
                point.InitStruct();
                memset(&point, 0, sizeof (point));
                
                point.Position.Actuators.Actuator1 = 0.0;
                point.Position.Actuators.Actuator2 = 0.0;
                point.Position.Actuators.Actuator3 = 0.0;
                point.Position.Actuators.Actuator4 = 0.0;
                point.Position.Actuators.Actuator5 = 0.0;
                point.Position.Actuators.Actuator6 = 0.0;
                

                // The trajectory consists of angular velocity waypoints
                point.Position.Type = ANGULAR_VELOCITY;
                
                reached_goal = true;
                bool exit_now = false;//is something really wrong
                setPControllerJointVelocity(point.Position.Actuators.Actuator1, error.Actuator1,  reached_goal, exit_now);
                setPControllerJointVelocity(point.Position.Actuators.Actuator2, error.Actuator2,  reached_goal, exit_now);
                setPControllerJointVelocity(point.Position.Actuators.Actuator3, error.Actuator3,  reached_goal, exit_now);
                setPControllerJointVelocity(point.Position.Actuators.Actuator4, error.Actuator4,  reached_goal, exit_now);
                setPControllerJointVelocity(point.Position.Actuators.Actuator5, error.Actuator5,  reached_goal, exit_now);
                setPControllerJointVelocity(point.Position.Actuators.Actuator6, error.Actuator6,  reached_goal, exit_now);
                if(exit_now)
                {
                    ROS_ERROR_STREAM("Way to large of error in JacoTrajectoryActionServer actuator setting to aborted");
                    action_server_.setAborted();
                    ROS_INFO_STREAM("Leaving: JacoTrajectoryActionServer::actionCallback\n");
                    return;
                }
                
                // Adjust actuator velocities accordingly
                arm_comm_.addTrajectoryPoint(point);
                ros::spinOnce();
                // Ensure execution at 100Hz
                r.sleep();
            }
            
            // If we got here, it seems that we succeeded
            action_server_.setSucceeded();

        } catch (const std::exception& e) {
            // Something rather terrible has happened - report it!
            ROS_ERROR_STREAM(e.what());
            action_server_.setAborted();
        }
    }
Пример #5
0
void Camera::offsetOrientation(float upAngle, float rightAngle) {
    _horizontalAngle += rightAngle;
    _verticalAngle += upAngle;
    normalizeAngles();
}
Пример #6
0
void Camera::lookAt(vec3 position) {
  vec3 direction = normalize(position - _position);
  _verticalAngle = degrees(asinf(-direction.y));
  _horizontalAngle = -degrees(atan2f(-direction.x, -direction.z));
  normalizeAngles();
}
Пример #7
0
	void lookAt(glm::vec3 point) {
		glm::vec3 dir = glm::normalize(point - pos_);
		vertAngle_ = glm::radians(asinf(-dir.y));
		horAngle_ = -glm::radians(atan2f(-dir.x, -dir.z));
		normalizeAngles();
	}
Пример #8
0
	void rotate(float up, float right) {
		horAngle_ += right;
		vertAngle_ += up;
		normalizeAngles();
	}
Пример #9
0
void Camera::offsetOrientation(float theta, float phi)
{
	m_theta += theta;
	m_phi	+= phi; 
	normalizeAngles();
}
Пример #10
0
void Camera::incOrientation(float rightAngle, float upAngle)
{
	mHorizontalAngle += rightAngle;
	mVerticalAngle += upAngle;
	normalizeAngles();
}