clear
clc
close all

rng(100)

% Parameters setting
d = 2000; % dimension
s = 20; % sparsity
beta = 100; % signal strength

k = s; % sparsity parameter for TPM
t_max = 1000; % maximum number of iterations for TPM

%% Generate underlying signal
u = zeros(d,1); % underlying signal
T = randperm(d,s); % supp(u) = T
u_T = randn(s,1);
u_T(u_T >= 0) = 1; % the signal with same abs.
u_T(u_T < 0) = -1;
u(T) = u_T/norm(u_T,2);

%% Generate noisy matrx Y = beta u u' + W
A = randn(d); 
Y = beta*(u*u') + (A + A')/sqrt(2);

%% Column thresholding
dist_col = column_thresholding(u,Y,d,s);

%% TPM
dist_TPM = TPM(u,Y,d,s,k,t_max);





