function time = pointset_rosen()
    
    clear;
    close all;
        
    load("C_rosen.mat");
    rawpy = C_rosen;
    
    n = size(rawpy,1)/4;
    
    temp = zeros(n,n,7);
    
    
    for i = 1:1:n
        for j = 1:1:n
            A = rawpy((4*i-3):4*i,(4*j-3):4*j);
            RR = A(1:3,1:3); 
            tt = A(1:3,4);   
            q = quaternion(RR,"rotmat","point");
            temp(i, j, 1:3) = tt;
            temp(i, j, 4:7) = compact(q);
     
        end
    end
    
    data = temp;
    edge_id = 0;
    for i = 1:1:n
        for j = i:1:n
            if data(i,j,4) ~= 0
                edge_id = edge_id+1;
                edges(edge_id, :) = [i, j];
                t{edge_id} = [data(i,j,1),data(i,j,2),data(i,j,3)]';
                q = [data(i,j,4),data(i,j,5),data(i,j,6),data(i,j,7)]';
                R{edge_id} = quat2rot(q);
            end
        end
    end
    
    measurements.edges = edges;
    measurements.R = R;
    measurements.t = t;
    
    num_poses = max(max(measurements.edges));
    num_measurements = length(measurements.t);
    
    measurements.kappa = repmat({100}, 1, num_measurements);
    measurements.tau = repmat({10}, 1, num_measurements);
    d = length(measurements.t{1});
    
    %% Set Manopt options (if desired)
    Manopt_opts.tolgradnorm = 1e-2;  % Stopping tolerance for norm of Riemannian gradient
    Manopt_opts.rel_func_tol = 1e-5;  % Additional stopping criterion for Manopt: stop if the relative function decrease between two successive accepted iterates is less than this value
    Manopt_opts.miniter = 1;  % Minimum number of outer iterations (i.e. accepted update steps) to perform
    Manopt_opts.maxiter = 300;  % Maximum number of outer iterations (i.e. accepted update steps) to perform
    Manopt_opts.maxinner = 500;  % Maximum number of iterations for the conjugate-gradient method used to compute approximate Newton steps
    %manopt_options.maxtime = 60*60;  % Maximum computation time to allow, in seconds
    %manopt_options.solver = @steepestdescent;  % Select Manopt solver to use: {trustregions (default), conjugategradient, steepestdescent}
    
    
    %% Set SE-Sync options (if desired)
    SE_Sync_opts.r0 = 5;  % Initial maximum-rank parameter at which to start the Riemannian Staircase
    SE_Sync_opts.rmax = 10;  % Maximum maximum-rank parameter at which to terminate the Riemannian Staircase
    SE_Sync_opts.eig_comp_rel_tol = 1e-4;  % Relative tolerance for the minimum-eigenvalue computation used to test for second-order optimality with MATLAB's eigs() function
    SE_Sync_opts.min_eig_lower_bound = -1e-3;  % Minimum eigenvalue threshold for accepting a maxtrix as numerically positive-semidefinite
    SE_Sync_opts.Cholesky = false;  % Select whether to use Cholesky or QR decomposition to compute orthogonal projections
    
    use_chordal_initialization = true;  % Select whether to use the chordal initialization, or a random starting point
    
    %% Run SE-Sync
    
    % Pass explict settings for SE-Sync and/or Manopt, and use chordal
    % initialization
    clock = tic;
    fprintf('Computing chordal initialization...\n');
    R = chordal_initialization(measurements);
    Y0 = vertcat(R, zeros(SE_Sync_opts.r0 - d, num_poses*d));
    [SDPval, Yopt, xhat, Fxhat, SE_Sync_info, problem_data] = SE_Sync(measurements, Manopt_opts, SE_Sync_opts, Y0);
    time = toc(clock);

    % ... or ...
    
%     % Use default settings for everything
%     clock = tic;
%     [SDPval, Yopt, xhat, Fxhat, se_sync_info, problem_data, total_computation_time] = SE_Sync(measurements);
%     time = toc(clock);

    
    
    %%
    
    R_vec = xhat.R;
    t_vec = xhat.t;
    r_rosen = zeros(n,4);
    t_rosen = zeros(n,3);
    
    for i = 1:1:n
        RR = R_vec(1:3,3*i-2:3*i);
        qq = quaternion(RR,"rotmat","frame"); 
        r_rosen(i,:) = compact(qq);
        tt = t_vec(:,i);
        t_rosen(i,:) = tt;
    end
    
    save("r_rosen.mat",'r_rosen');
    save("t_rosen.mat",'t_rosen');



end