function [ O ] = generate_O( d , L, mag, sigma )

O = nan( d , L );

O( : , 1 ) = mag * [ 1 ; zeros( d - 1 , 1 ) ];

O( : , 2 ) = mag * [ 0 ; 1 ; zeros( d - 2 , 1 ) ];

for i = 3 :  L
    
    O_temp = rand( d - 2 , 1 );
    
    O_temp = mag * O_temp / norm( O_temp );
    
    O( : , i ) = [ 0 ; 0 ; O_temp ];
    
end

O = O + sigma * randn( size(O) );

end

