function [left_idxs, right_idxs, threshold, split_dir, proj_data] = split_PCA(DATA, params)
if ~isfield(params,'spill')
    params.spill = 0;
end

centerDATA = DATA - repmat(mean(DATA,1),size(DATA,1),1);

[~,~,dir] = svds(centerDATA,1);

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;

