forked from jduffield65/iss
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathiss_color_diagnostics.m
36 lines (27 loc) · 1.25 KB
/
iss_color_diagnostics.m
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
function iss_color_diagnostics(o)
% iss_color_diagnostics(o)
%
% does some diagnostics of signal and noise in each color channel and
% round. Makes a matrix of histograms. In each one, the blue bars are the
% histogram of intensities on spots which should not have fluorescence on
% that color and round. The red bars are the ones that should have
% fluorescence. So the red bars should be to the right of the blue ones.
% Note the same x-axis scale is used for all rounds of one color, but
% differs between colors
nc = size(o.dpSpotColors,2);
nr = size(o.dpSpotColors,3);
figure(349075); clf;
nBins = 50;
for c=1:nc
for r=1:nr
rc = (r-1)*o.nBP + c;
subplot(nr,nc,rc);
ShouldBe1(o.dpSpotCombi) = (o.UnbledCodes(o.dpSpotCodeNo(o.dpSpotCombi),rc)>0);
cla; hold on
MaxVal = prctile(reshape(o.dpSpotColors(:,c,:),1,[]),99);
histogram(o.dpSpotColors(~ShouldBe1,c,r), nBins, 'BinLimits', [0 MaxVal], 'FaceColor', 'b', 'EdgeColor', 'b', 'Normalization', 'probability');
histogram(o.dpSpotColors( ShouldBe1,c,r), nBins, 'BinLimits', [0 MaxVal], 'FaceColor', 'r', 'EdgeColor', 'r', 'Normalization', 'probability');
title(sprintf('Color %d Round %d', c-1, r))
% set(gca, 'yscale', 'log')
end
end