% this is a file for dealing with the groundtruth documents


clear;
close all;
thisDir = fileparts(mfilename('fullpath'));
addpath(genpath(thisDir));

% input_file = 'bunny/data/bun.conf';  
% input_file = 'happy/data/happy_stand/happyStandRight.conf'; 
% input_file = 'dragon_stand/dragonStandRight.conf';
input_file = 'Armadillo/ArmadilloStand.conf';

% Output file path

bmesh_matrix = [];

fid = fopen(input_file, 'r');
if fid == -1
    error('Failed to open the file.');
end

% Read the file line by line
line = fgetl(fid);  
while ischar(line)
    % Split the line into parts
    parts = strsplit(strtrim(line));
    
    % Process only lines starting with 'bmesh'
    if strcmp(parts{1}, 'bmesh')
        % Extract the numeric values (ignoring the filename)
        bmesh_values = str2double(parts(3:end));
        % Append the values as a new row in the matrix
        bmesh_matrix = [bmesh_matrix; bmesh_values];
    end
    
    % Read the next line
    line = fgetl(fid);
end

% Close the file
fclose(fid); 

temp = zeros(size(bmesh_matrix,1),7);
temp(:,1:3) = bmesh_matrix(:,1:3);
temp(:,4) = bmesh_matrix(:,7);
temp(:,5:7) = bmesh_matrix(:,4:6);

% gtVec0 = temp;
% save("gtVec0.mat", 'gtVec0');


temp_t = temp(:,1:3);
temp_r = temp(:,4:7);
temp_rt = quatrotate(quatconj(temp_r), temp_t);

gtVec2 = [-temp_rt,temp_r];

% Save the bmesh data to a .mat file
save("gtVec2.mat", 'gtVec2');

disp(['BMesh data saved']);