Exemple #1
0
def GeoRegistration_field():
    # Geo-Registration: field data captured by mynteye and starfire
    kf_file = '/home/shu/OpensourceProject/MYNT-ORBSLAM2_ws/src/MYNT-EYE-ORB-SLAM2-Sample/pose_graph/KeyFrameTrajectory.txt'
    timestamps_pg = []
    with open(kf_file, 'r') as fp:
        for line in fp:
            timestamps_pg.append(line.split(' ')[0])

    csv_file_path = "/home/shu/Desktop/SF3000-recordings/2019_07_15_2047_17_perceptionLog_StructSensorSF3000.csv"
    PVT_msg, INS_msg, IMU_msg = gps_data_analysis.read_gps_data(csv_file_path)
    timestamps_pvt, easting, northing, altitude, velocityEasting, velocityNorthing, velocityUp = gps_data_analysis.sparse_PVT_msg(
        PVT_msg)

    # Set first measurement of GPS as origin point
    timestamps_pvt = np.asarray(timestamps_pvt)
    X = np.asarray([(item - easting[0]) for item in easting])
    Y = np.asarray([(item - northing[0]) for item in northing])
    Z = np.asarray([(item - altitude[0]) for item in altitude])

    plt.plot(X, Y)

    X_interp = np.interp(timestamps_pg, timestamps_pvt, X)
    Y_interp = np.interp(timestamps_pg, timestamps_pvt, Y)
    Z_interp = np.interp(timestamps_pg, timestamps_pvt, Z)

    with open('./ref_images_field.txt', 'w') as fp:
        for i in range(len(X_interp)):
            img_name = ""
            if i < 10:
                img_name = "00000" + str(i)
            elif i > 9 and i < 100:
                img_name = "0000" + str(i)
            elif i > 99 and i < 1000:
                img_name = "000" + str(i)
            elif i > 999 and i < 10000:
                img_name = "00" + str(i)
            elif i > 9999 and i < 100000:
                img_name = "0" + str(i)
            fp.write('%s %f %f %f \n' % ('IMG' + img_name + '.png', X_interp[i], Y_interp[i], Z_interp[i]))
Exemple #2
0
import numpy as np
from numpy import pi
import matplotlib.pyplot as plt
from mpl_toolkits.mplot3d import Axes3D
import gps_data_analysis
from numpy.linalg import inv
import quaternion
from scipy.interpolate import RegularGridInterpolator

## TODO: VINS + GPS, I was trying to combine GPS and mynteye IMU, see if VINS can calibrate extrinsic parameter online
## TODO: This idea is not success!
## TODO: Not success!

csv_file_path = "/home/shu/Desktop/SF3000-recordings/2019_07_15_2047_17_perceptionLog_StructSensorSF3000.csv"
PVT_msg, INS_msg, IMU_msg = gps_data_analysis.read_gps_data(csv_file_path)
timestamps_imu, xAccel, yAccel, zAccel, xGyroRate, yGyroRate, zGyroRate = gps_data_analysis.sparse_IMU_msg(
    IMU_msg)
# timestamps_pvt, easting, northing, altitude, velocityEasting, velocityNorthing, velocityUp = gps_data_analysis.sparse_PVT_msg(PVT_msg)
#
# timestamps_pvt = np.asarray(timestamps_pvt)
# X = np.asarray([(item - easting[0]) for item in easting])
# Y = np.asarray([(item - northing[0]) for item in northing])
# Z = np.asarray([(item - altitude[0]) for item in altitude])

with open('/home/shu/kalibr_workspace/MYNTEYE_GPS_VINS_testdata/imu0.csv',
          'a') as fp:
    for i in range(len(timestamps_imu)):
        tmp = ("%.9f" % timestamps_imu[i]).replace('.', '')
        print(tmp)
        fp.write('%s,%f,%f,%f,%f,%f,%f\n' %
                 (tmp, xAccel[i], yAccel[i], zAccel[i], xGyroRate[i],