function [ X , Y , A] = generate_GX( N , O , M )

[ d , T ] = size( O );

N_p = floor( N / 2 );

N_g = N - N_p;

X = nan( d * M, N_p + N_g );

Y = nan( 1 , N_p + N_g  );

v = 3 : T;

A = eye( N_p + N_g );

X_g = nan( d , N_p + N_g );

v1 = floor( N_p * 0.1 );

v2 = floor( N_g * 0.1 );

v1_index = 1 : v1;

v2_index = v1 + 1 : v1 + v2;

v3_index = v1+v2+1: N_g + N_p;

X_g( : , v1_index ) = repmat( O( : , 1 ), 1, v1 );

Y( v1_index ) = 1;

Y( v2_index ) = -1;

Y(v1+v2+1 : v1+v2+ (N_p - v1)) = 1;

Y(v1+v2+ (N_p - v1) + 1 : N_p + N_g) = -1;

X_g( : , v2_index ) = repmat( O( : , 2 ), 1, v2 );

X_g( : , v3_index ) = O( : , randsample( v , length( v3_index ), true ) );

for i = v1+v2+1 : v1+v2+ (N_p - v1)
    
   temp = randsample( v1_index , 1, true );
   
   A( temp , i ) = 1;
   
   A( i , temp ) = 1;
    
end

for i = v1+v2+ (N_p - v1) + 1 : N_p + N_g
    
   temp = randsample( v2_index , 1, true );
   
   A( temp , i ) = 1;
   
   A( i , temp ) = 1;
    
end

A_1 = zeros(length(v3_index));

delta = floor( M / 2 ) * 2;

a = [ ones(1, delta/2+1) , zeros(1,length(v3_index)-delta-1), ones(1, delta/2)];

for i = 1: length( v3_index )
    
    A_1(i,:) =a;
    
    a = circshift(a,1);

end

A( v3_index , v3_index ) = A( v3_index , v3_index ) + A_1;

for n = 1 : size( X , 2 )
   
    temp_x = zeros( d , M );
    
    temp_index =  find( A( n , : ) ~= 0 );
    
    temp_index = temp_index( 1 : min(length(temp_index) , M) );
   
    temp_x( :, 1 : length(temp_index) ) = X_g( :, temp_index );
    
    X( : , n ) = reshape( temp_x , d * M , 1 );
    
end




