forked from MouseLightPipeline/pipeline-featmatch
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathtest_pointmatch_on_single_pair_using_production_inputs.m
79 lines (69 loc) · 4.29 KB
/
test_pointmatch_on_single_pair_using_production_inputs.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
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
function test_pointmatch_on_single_pair_using_production_inputs(sample_date, central_tile_relative_path)
% Build/load the tile index
this_folder = fileparts(mfilename('fullpath')) ;
memo_folder_path = fullfile(this_folder, 'memos') ;
do_force_computation = false ;
raw_tiles_path = fullfile('/groups/mousebrainmicro/mousebrainmicro/data', sample_date, 'Tiling') ;
raw_tile_index = compute_or_read_from_memo(memo_folder_path, ...
sprintf('raw-tile-index-%s', sample_date), ...
@()(build_raw_tile_index(raw_tiles_path)), ...
do_force_computation) ;
tile_index_from_ijk1 = raw_tile_index.tile_index_from_ijk1 ;
ijk1_from_tile_index = raw_tile_index.ijk1_from_tile_index ;
%xyz_from_tile_index = raw_tile_index.xyz_from_tile_index ;
relative_path_from_tile_index = raw_tile_index.relative_path_from_tile_index ;
tile_lattice_shape = size(tile_index_from_ijk1)
tile_count = length(relative_path_from_tile_index)
% Find the problematic pair
%central_tile_relative_path = '2020-12-01/01/01916'
central_tile_index = find(strcmp(central_tile_relative_path, relative_path_from_tile_index))
central_tile_ijk1 = ijk1_from_tile_index(central_tile_index, :) %#ok<FNDSB>
other_tile_ijk1 = central_tile_ijk1 + [0 0 1] ;
other_tile_index = tile_index_from_ijk1(other_tile_ijk1(1), other_tile_ijk1(2), other_tile_ijk1(3))
other_tile_relative_path = relative_path_from_tile_index{other_tile_index}
% Set paths to inputs, outputs
tile1 = fullfile('/nrs/mouselight/pipeline_output', sample_date, 'stage_3_descriptor_output', central_tile_relative_path) ;
tile2 = fullfile('/nrs/mouselight/pipeline_output', sample_date, 'stage_3_descriptor_output', other_tile_relative_path) ;
acqusitionfolder1 = fullfile('/groups/mousebrainmicro/mousebrainmicro/data', sample_date, 'Tiling', central_tile_relative_path) ;
acqusitionfolder2 = fullfile('/groups/mousebrainmicro/mousebrainmicro/data', sample_date, 'Tiling', other_tile_relative_path) ;
output_folder_path = fullfile(this_folder, 'test-outputs', sample_date, 'stage_4_point_match_output', central_tile_relative_path) ;
target_folder_path = fullfile('/nrs/mouselight/pipeline_output', sample_date, 'stage_4_point_match_output', central_tile_relative_path) ;
% We try to delete all files in output_folder_path, so first make sure it's not
% empty
if isempty(output_folder_path) ,
error('No output folder set') ;
end
% Delete any pre-existing output files
return_code = system(sprintf('rm -rf %s/*', output_folder_path)) ;
if return_code ~= 0 ,
error('Unable to delete contents of %s for test', output_folder_path) ;
end
% Run the code under test
pixel_shift = '[0 0 0]' ;
ch = [] ; % this is ignored
max_descriptor_count = 10000 ;
exitcode = pointmatch(tile1, tile2, acqusitionfolder1, acqusitionfolder2, output_folder_path, pixel_shift, ch, max_descriptor_count) ;
if exitcode ~= 0 ,
error('pointmatch() returned a nonzero exit code (%s) when trying to produce output in folder %s', exitcode, output_folder_path) ;
end
% Load the output, and the target
output_file_path = fullfile(output_folder_path, 'channel-1-match-Z.mat') ;
target_file_path = fullfile(target_folder_path, 'match-Z.mat') ;
output = load(output_file_path) ;
target = load(target_file_path) ;
% Give an overview of the results
fprintf('output.paireddescriptor:\n') ;
disp(output.paireddescriptor) ;
fprintf('target.paireddescriptor:\n') ;
disp(target.paireddescriptor) ;
% Compare output and target
if ~( isequal(output.paireddescriptor.X, target.paireddescriptor.X) && isequal(output.paireddescriptor.Y, target.paireddescriptor.Y)) ,
error('Output for sample %s, central tile %s does not match target', sample_date, central_tile_relative_path) ;
end
% Make sure the other output file exists and is readable
output_file_path = fullfile(output_folder_path, 'channel-0-match-Z.mat') ;
output = load(output_file_path) ;
fprintf('output.paireddescriptor (channel 0):\n') ;
disp(output.paireddescriptor) ;
% If get here without error, success!
end