function [left_idxs, right_idxs, threshold, split_dir, proj_data] = split_2M(DATA, params)
if ~isfield(params,'spill')
    params.spill = 0;
end

[~,c] = kmeans(DATA,2);
dir = c(2,:)-c(1,:);
dir = dir'/norm(dir);

projDATA = DATA * dir;
thresh = median(projDATA,1);

prc = prctile(projDATA,[0.5-params.spill, 0.5+params.spill]*100);

comm_idx  = projDATA>prc(1) & projDATA<prc(2);
idx_left  = projDATA <= thresh;
idx_right = projDATA > thresh;

split_dir = dir;
threshold = thresh;
left_idxs = idx_left | comm_idx;
right_idxs = idx_right | comm_idx;
proj_data = projDATA;

