function [ y_est ] = generate_y( W , V , X)

[ d , K ] = size( W );

[ p , N ] = size( X );

M = p / d;

y_est = zeros( 1 , N );

for k = 1 : K
    
    w = W( : , k);
    
    v = V( : , k);
   
    w_r = dig( w , M );
    
    v_r = dig( v , M );
   
    y_est = y_est + 1/K * max( max( w_r * X ), 0) -  1/K * max( max( v_r * X ), 0);

end


end

function [ w_k ] = dig( w , M )

d = length( w );

w_k = nan( M , d*M );

o_1 = [ w' , zeros( 1 , d * ( M - 1 ) ) ];

for i = 1 : M
    
    w_k( i , : ) = o_1;
    
    o_1 = circshift( o_1 , d );
    
end

end


