function test_vector_transport
clc;clear all;close all;
n = 4;
r = 3;
X = randn(n,r);X1 = randn(n,r);
X = oproj(X);X1 = oproj(X1);
G = randn(n,r)*100;
eta = G - X*G'*X; % eta \in T_x(M)

eta'*X+X'*eta
 ddd

G1 = randn(n,r)*100;
xi = G1 - X*G1'*X; % eta \in T_x(M)
G2 = randn(n,r)*100;
zeta = G2 - X*G2'*X; % eta \in T_x(M)

T = Transport(eta,xi,X);
T'*retr(X,eta) + retr(X,eta)'*T


a = randn(1);
b = randn(1);
Transport(eta,a*xi+b*zeta,X)  - a*Transport(eta,xi,X)  - b*Transport(eta,zeta,X) 

% T'*X + X'*T
