OLD | NEW |
(Empty) | |
| 1 #!/bin/bash |
| 2 |
| 3 set -u |
| 4 set -e |
| 5 trap onexit INT |
| 6 trap onexit TERM |
| 7 trap onexit EXIT |
| 8 |
| 9 onexit() |
| 10 { |
| 11 if [ -d $OUTDIR ]; then |
| 12 rm -rf $OUTDIR |
| 13 fi |
| 14 } |
| 15 |
| 16 runme() |
| 17 { |
| 18 echo \*\*\* $* |
| 19 $* |
| 20 } |
| 21 |
| 22 IMAGES="vgl_5674_0098.bmp vgl_6434_0018a.bmp vgl_6548_0026a.bmp nightshot_iso_10
0.bmp" |
| 23 IMGDIR=@srcdir@/testimages |
| 24 OUTDIR=__tjexampletest_output |
| 25 EXEDIR=. |
| 26 JAVA="@JAVA@ -cp java/turbojpeg.jar -Djava.library.path=.libs" |
| 27 |
| 28 if [ -d $OUTDIR ]; then |
| 29 rm -rf $OUTDIR |
| 30 fi |
| 31 mkdir -p $OUTDIR |
| 32 |
| 33 exec >$EXEDIR/tjexampletest.log |
| 34 |
| 35 for image in $IMAGES; do |
| 36 |
| 37 cp $IMGDIR/$image $OUTDIR |
| 38 basename=`basename $image .bmp` |
| 39 $EXEDIR/cjpeg -quality 95 -dct fast -grayscale $IMGDIR/${basename}.bmp >
$OUTDIR/${basename}_GRAY_fast_cjpeg.jpg |
| 40 $EXEDIR/cjpeg -quality 95 -dct fast -sample 2x2 $IMGDIR/${basename}.bmp
>$OUTDIR/${basename}_420_fast_cjpeg.jpg |
| 41 $EXEDIR/cjpeg -quality 95 -dct fast -sample 2x1 $IMGDIR/${basename}.bmp
>$OUTDIR/${basename}_422_fast_cjpeg.jpg |
| 42 $EXEDIR/cjpeg -quality 95 -dct fast -sample 1x1 $IMGDIR/${basename}.bmp
>$OUTDIR/${basename}_444_fast_cjpeg.jpg |
| 43 $EXEDIR/cjpeg -quality 95 -dct int -grayscale $IMGDIR/${basename}.bmp >$
OUTDIR/${basename}_GRAY_accurate_cjpeg.jpg |
| 44 $EXEDIR/cjpeg -quality 95 -dct int -sample 2x2 $IMGDIR/${basename}.bmp >
$OUTDIR/${basename}_420_accurate_cjpeg.jpg |
| 45 $EXEDIR/cjpeg -quality 95 -dct int -sample 2x1 $IMGDIR/${basename}.bmp >
$OUTDIR/${basename}_422_accurate_cjpeg.jpg |
| 46 $EXEDIR/cjpeg -quality 95 -dct int -sample 1x1 $IMGDIR/${basename}.bmp >
$OUTDIR/${basename}_444_accurate_cjpeg.jpg |
| 47 for samp in GRAY 420 422 444; do |
| 48 $EXEDIR/djpeg -rgb -bmp $OUTDIR/${basename}_${samp}_fast_cjpeg.j
pg >$OUTDIR/${basename}_${samp}_default_djpeg.bmp |
| 49 $EXEDIR/djpeg -dct fast -rgb -bmp $OUTDIR/${basename}_${samp}_fa
st_cjpeg.jpg >$OUTDIR/${basename}_${samp}_fast_djpeg.bmp |
| 50 $EXEDIR/djpeg -dct int -rgb -bmp $OUTDIR/${basename}_${samp}_acc
urate_cjpeg.jpg >$OUTDIR/${basename}_${samp}_accurate_djpeg.bmp |
| 51 done |
| 52 for samp in 420 422; do |
| 53 $EXEDIR/djpeg -nosmooth -bmp $OUTDIR/${basename}_${samp}_fast_cj
peg.jpg >$OUTDIR/${basename}_${samp}_default_nosmooth_djpeg.bmp |
| 54 $EXEDIR/djpeg -dct fast -nosmooth -bmp $OUTDIR/${basename}_${sam
p}_fast_cjpeg.jpg >$OUTDIR/${basename}_${samp}_fast_nosmooth_djpeg.bmp |
| 55 $EXEDIR/djpeg -dct int -nosmooth -bmp $OUTDIR/${basename}_${samp
}_accurate_cjpeg.jpg >$OUTDIR/${basename}_${samp}_accurate_nosmooth_djpeg.bmp |
| 56 done |
| 57 |
| 58 # Compression |
| 59 for dct in fast accurate; do |
| 60 for samp in GRAY 420 422 444; do |
| 61 runme $JAVA TJExample $OUTDIR/$image $OUTDIR/${basename}
_${samp}_${dct}.jpg -q 95 -samp ${samp} -${dct}dct |
| 62 runme cmp $OUTDIR/${basename}_${samp}_${dct}.jpg $OUTDIR
/${basename}_${samp}_${dct}_cjpeg.jpg |
| 63 done |
| 64 done |
| 65 |
| 66 # Decompression |
| 67 for dct in fast accurate default; do |
| 68 srcdct=${dct} |
| 69 dctarg=-${dct}dct |
| 70 if [ "${dct}" = "default" ]; then |
| 71 srcdct=fast |
| 72 dctarg= |
| 73 fi |
| 74 for samp in GRAY 420 422 444; do |
| 75 runme $JAVA TJExample $OUTDIR/${basename}_${samp}_${srcd
ct}.jpg $OUTDIR/${basename}_${samp}_${dct}.bmp ${dctarg} |
| 76 runme cmp -i 54:54 $OUTDIR/${basename}_${samp}_${dct}.bm
p $OUTDIR/${basename}_${samp}_${dct}_djpeg.bmp |
| 77 rm $OUTDIR/${basename}_${samp}_${dct}.bmp |
| 78 done |
| 79 for samp in 420 422; do |
| 80 runme $JAVA TJExample $OUTDIR/${basename}_${samp}_${srcd
ct}.jpg $OUTDIR/${basename}_${samp}_${dct}_nosmooth.bmp -fastupsample ${dctarg} |
| 81 runme cmp -i 54:54 $OUTDIR/${basename}_${samp}_${dct}_no
smooth.bmp $OUTDIR/${basename}_${samp}_${dct}_nosmooth_djpeg.bmp |
| 82 rm $OUTDIR/${basename}_${samp}_${dct}_nosmooth.bmp |
| 83 done |
| 84 done |
| 85 |
| 86 # Scaled decompression |
| 87 for scale in 2_1 15_8 7_4 13_8 3_2 11_8 5_4 9_8 7_8 3_4 5_8 1_2 3_8 1_4
1_8; do |
| 88 scalearg=`echo $scale | sed s@_@/@g` |
| 89 for samp in GRAY 420 422 444; do |
| 90 $EXEDIR/djpeg -rgb -bmp -scale ${scalearg} $OUTDIR/${bas
ename}_${samp}_fast_cjpeg.jpg >$OUTDIR/${basename}_${samp}_${scale}_djpeg.bmp |
| 91 runme $JAVA TJExample $OUTDIR/${basename}_${samp}_fast.j
pg $OUTDIR/${basename}_${samp}_${scale}.bmp -scale ${scalearg} |
| 92 runme cmp -i 54:54 $OUTDIR/${basename}_${samp}_${scale}.
bmp $OUTDIR/${basename}_${samp}_${scale}_djpeg.bmp |
| 93 rm $OUTDIR/${basename}_${samp}_${scale}.bmp |
| 94 done |
| 95 done |
| 96 |
| 97 # Transforms |
| 98 for samp in GRAY 420 422 444; do |
| 99 $EXEDIR/jpegtran -crop 70x60+16+16 -flip horizontal -trim $OUTDI
R/${basename}_${samp}_fast.jpg >$OUTDIR/${basename}_${samp}_hflip_jpegtran.jpg |
| 100 $EXEDIR/jpegtran -crop 70x60+16+16 -flip vertical -trim $OUTDIR/
${basename}_${samp}_fast.jpg >$OUTDIR/${basename}_${samp}_vflip_jpegtran.jpg |
| 101 $EXEDIR/jpegtran -crop 70x60+16+16 -transpose -trim $OUTDIR/${ba
sename}_${samp}_fast.jpg >$OUTDIR/${basename}_${samp}_transpose_jpegtran.jpg |
| 102 $EXEDIR/jpegtran -crop 70x60+16+16 -transverse -trim $OUTDIR/${b
asename}_${samp}_fast.jpg >$OUTDIR/${basename}_${samp}_transverse_jpegtran.jpg |
| 103 $EXEDIR/jpegtran -crop 70x60+16+16 -rotate 90 -trim $OUTDIR/${ba
sename}_${samp}_fast.jpg >$OUTDIR/${basename}_${samp}_rot90_jpegtran.jpg |
| 104 $EXEDIR/jpegtran -crop 70x60+16+16 -rotate 180 -trim $OUTDIR/${b
asename}_${samp}_fast.jpg >$OUTDIR/${basename}_${samp}_rot180_jpegtran.jpg |
| 105 $EXEDIR/jpegtran -crop 70x60+16+16 -rotate 270 -trim $OUTDIR/${b
asename}_${samp}_fast.jpg >$OUTDIR/${basename}_${samp}_rot270_jpegtran.jpg |
| 106 done |
| 107 for xform in hflip vflip transpose transverse rot90 rot180 rot270; do |
| 108 for samp in GRAY 420 422 444; do |
| 109 runme $JAVA TJExample $OUTDIR/${basename}_${samp}_fast.j
pg $OUTDIR/${basename}_${samp}_${xform}.jpg -$xform -crop 16,16,70x60 |
| 110 runme cmp $OUTDIR/${basename}_${samp}_${xform}.jpg $OUTD
IR/${basename}_${samp}_${xform}_jpegtran.jpg |
| 111 $EXEDIR/djpeg -rgb -bmp $OUTDIR/${basename}_${samp}_${xf
orm}_jpegtran.jpg >$OUTDIR/${basename}_${samp}_${xform}_jpegtran.bmp |
| 112 runme $JAVA TJExample $OUTDIR/${basename}_${samp}_fast.j
pg $OUTDIR/${basename}_${samp}_${xform}.bmp -$xform -crop 16,16,70x60 |
| 113 runme cmp -i 54:54 $OUTDIR/${basename}_${samp}_${xform}.
bmp $OUTDIR/${basename}_${samp}_${xform}_jpegtran.bmp |
| 114 rm $OUTDIR/${basename}_${samp}_${xform}.bmp |
| 115 done |
| 116 for samp in 420 422; do |
| 117 $EXEDIR/djpeg -nosmooth -rgb -bmp $OUTDIR/${basename}_${
samp}_${xform}_jpegtran.jpg >$OUTDIR/${basename}_${samp}_${xform}_jpegtran.bmp |
| 118 runme $JAVA TJExample $OUTDIR/${basename}_${samp}_fast.j
pg $OUTDIR/${basename}_${samp}_${xform}.bmp -$xform -crop 16,16,70x60 -fastupsam
ple |
| 119 runme cmp -i 54:54 $OUTDIR/${basename}_${samp}_${xform}.
bmp $OUTDIR/${basename}_${samp}_${xform}_jpegtran.bmp |
| 120 rm $OUTDIR/${basename}_${samp}_${xform}.bmp |
| 121 done |
| 122 done |
| 123 |
| 124 # Grayscale transform |
| 125 for xform in hflip vflip transpose transverse rot90 rot180 rot270; do |
| 126 for samp in GRAY 444 422 420; do |
| 127 runme $JAVA TJExample $OUTDIR/${basename}_${samp}_fast.j
pg $OUTDIR/${basename}_${samp}_${xform}.jpg -$xform -grayscale -crop 16,16,70x60 |
| 128 runme cmp $OUTDIR/${basename}_${samp}_${xform}.jpg $OUTD
IR/${basename}_GRAY_${xform}_jpegtran.jpg |
| 129 runme $JAVA TJExample $OUTDIR/${basename}_${samp}_fast.j
pg $OUTDIR/${basename}_${samp}_${xform}.bmp -$xform -grayscale -crop 16,16,70x60 |
| 130 runme cmp -i 54:54 $OUTDIR/${basename}_${samp}_${xform}.
bmp $OUTDIR/${basename}_GRAY_${xform}_jpegtran.bmp |
| 131 rm $OUTDIR/${basename}_${samp}_${xform}.bmp |
| 132 done |
| 133 done |
| 134 |
| 135 # Transforms with scaling |
| 136 for xform in hflip vflip transpose transverse rot90 rot180 rot270; do |
| 137 for samp in GRAY 444 422 420; do |
| 138 for scale in 2_1 15_8 7_4 13_8 3_2 11_8 5_4 9_8 7_8 3_4
5_8 1_2 3_8 1_4 1_8; do |
| 139 scalearg=`echo $scale | sed s@_@/@g` |
| 140 $EXEDIR/djpeg -rgb -bmp -scale ${scalearg} $OUTD
IR/${basename}_${samp}_${xform}_jpegtran.jpg >$OUTDIR/${basename}_${samp}_${xfor
m}_${scale}_jpegtran.bmp |
| 141 runme $JAVA TJExample $OUTDIR/${basename}_${samp
}_fast.jpg $OUTDIR/${basename}_${samp}_${xform}_${scale}.bmp -$xform -scale ${sc
alearg} -crop 16,16,70x60 |
| 142 runme cmp -i 54:54 $OUTDIR/${basename}_${samp}_$
{xform}_${scale}.bmp $OUTDIR/${basename}_${samp}_${xform}_${scale}_jpegtran.bmp |
| 143 rm $OUTDIR/${basename}_${samp}_${xform}_${scale}
.bmp |
| 144 done |
| 145 done |
| 146 done |
| 147 |
| 148 done |
| 149 |
| 150 echo SUCCESS! |
OLD | NEW |