edu.umich.robot.util.Poses.java Source code

Java tutorial

Introduction

Here is the source code for edu.umich.robot.util.Poses.java

Source

/*
 * Copyright (c) 2011, Regents of the University of Michigan
 * 
 * Permission is hereby granted, free of charge, to any person obtaining a copy
 * of this software and associated documentation files (the "Software"), to deal
 * in the Software without restriction, including without limitation the rights
 * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
 * copies of the Software, and to permit persons to whom the Software is
 * furnished to do so, subject to the following conditions:
 * 
 * The above copyright notice and this permission notice shall be included in
 * all copies or substantial portions of the Software.
 * 
 * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
 * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
 * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
 * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
 * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
 * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
 * THE SOFTWARE.
 */
package edu.umich.robot.util;

import java.util.concurrent.TimeUnit;

import org.apache.commons.logging.Log;
import org.apache.commons.logging.LogFactory;

import april.jmat.LinAlg;
import april.jmat.MathUtil;
import april.lcmtypes.pose_t;

/**
 * @author voigtjr@gmail.com
 */
public class Poses {
    private static final Log logger = LogFactory.getLog(Poses.class);

    private static final double MIN_ELABORATION_INTERVAL_SEC = 0.010;

    public static pose_t elaborate(pose_t oldPose, pose_t newPose) {
        if (oldPose.utime == 0)
            return newPose;

        // elaborate to get velocities from odometry

        // (new usec - old usec) * 1 / usec in sec
        double dt = (newPose.utime - oldPose.utime) / (double) TimeUnit.MICROSECONDS.convert(1, TimeUnit.SECONDS);
        if (dt < MIN_ELABORATION_INTERVAL_SEC)
            return oldPose;

        // TODO: may need modification for smoothing
        newPose.vel[0] = (newPose.pos[0] - oldPose.pos[0]) * (1.0 / dt);
        newPose.vel[1] = (newPose.pos[1] - oldPose.pos[1]) * (1.0 / dt);

        double newTheta = LinAlg.quatToRollPitchYaw(newPose.orientation)[2];
        newTheta = MathUtil.mod2pi(newTheta);
        double oldTheta = LinAlg.quatToRollPitchYaw(oldPose.orientation)[2];
        oldTheta = MathUtil.mod2pi(oldTheta);
        newPose.rotation_rate[2] = MathUtil.mod2pi(newTheta - oldTheta) * (1.0 / dt);

        if (logger.isTraceEnabled()) {
            double xvel = LinAlg.rotate2(newPose.vel, -newTheta)[0];
            logger.trace(String.format("dt%1.5f vx%1.3f vy%1.3f r%1.3f xv%1.3f", dt, newPose.vel[0], newPose.vel[1],
                    newPose.rotation_rate[2], xvel));
        }

        return newPose;
    }
}