-
Notifications
You must be signed in to change notification settings - Fork 8
/
Copy pathAlign.sh
executable file
·76 lines (60 loc) · 1.85 KB
/
Align.sh
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
#!/bin/bash
# Part of Macro-scripts package (a complete Open Source workflow for processing macro focus stacking photographs)
# Written by Sergey Mashchenko
# Aligning focus stack, starting from the middle frame, and running two processes in parallel in the opposite directions.
# This ensures good framing for the aligned stack (minimizes frame waste) and accelerates the computations by 50-100%.
# Creates a set of aligned images with the names OUT0000.tif, OUT0001.tif and so on.
# If something goes wrong you might need to kill one or both running align_image_stack processes manually using
# pkill or kill.
echo
if test $# -lt 2
then
echo "Syntax: Align.sh [-l] image1 image2 [image3 ...]"
echo
echo -l: assume that the images have linear color space
echo
exit
fi
if test "$1" = "-l"
then
echo "Assuming linear color space"
OPT="$1"
else
OPT="-m"
fi
files=("$@")
N=$#
middle=$(($N / 2 - 1))
echo N=$N, middle=$middle
echo
# Reversing the order of files in the first half:
for e in "${files[@]:0:$middle+1}"
do
revfiles=( "$e" "${revfiles[@]}" )
done
# First half aligning:
align_image_stack "$OPT" --use-given-order -m -a P1_ ${revfiles[@]} &>out1.log &
# A 10s delay, to have a phase shift between two parallel processes:
sleep 10
# Second half aligning:
align_image_stack "$OPT" --use-given-order -m -a P2_ ${files[@]:$middle} &>out2.log &
# Waiting for both processes to finish:
wait
# Deleting the first file in the second half as it is identical to the last file in the first half:
\rm P2_0000.tif
# Renaming the outputs to become a single aligned stack
for name in P1_*
do
N1=`echo $name |cut -b 4-7`
N2=`echo $middle $N1 | awk '{printf "%04d\n", $1-$2}'`
mv $name OUT${N2}.tif
done
for name in P2_*
do
N1=`echo $name |cut -b 4-7`
N2=`echo $middle $N1 | awk '{printf "%04d\n", $1+$2}'`
mv $name OUT${N2}.tif
done
echo
echo "Success!"
echo