From 50c4ea6b35090aac53dcad3c3634bd95986e4493 Mon Sep 17 00:00:00 2001 From: Leonid Kostrykin Date: Thu, 25 Apr 2024 10:44:25 +0200 Subject: [PATCH] Add `repeat_channels` tool --- tools/repeat_channels/.shed.yml | 8 +++ tools/repeat_channels/creators.xml | 1 + tools/repeat_channels/repeat_channels.py | 19 ++++++ tools/repeat_channels/repeat_channels.xml | 61 ++++++++++++++++++ tools/repeat_channels/test-data/input1.tif | Bin 0 -> 70481 bytes tools/repeat_channels/test-data/input1_c3.tif | Bin 0 -> 210947 bytes tools/repeat_channels/tests.xml | 1 + 7 files changed, 90 insertions(+) create mode 100644 tools/repeat_channels/.shed.yml create mode 120000 tools/repeat_channels/creators.xml create mode 100644 tools/repeat_channels/repeat_channels.py create mode 100644 tools/repeat_channels/repeat_channels.xml create mode 100644 tools/repeat_channels/test-data/input1.tif create mode 100644 tools/repeat_channels/test-data/input1_c3.tif create mode 120000 tools/repeat_channels/tests.xml diff --git a/tools/repeat_channels/.shed.yml b/tools/repeat_channels/.shed.yml new file mode 100644 index 00000000..a9ea49f4 --- /dev/null +++ b/tools/repeat_channels/.shed.yml @@ -0,0 +1,8 @@ +categories: + - Imaging +description: Convert single-channel to multi-channel image +long_description: This tools converts a single-channel image to a multi-channel image by repeating the channel multiple times. +name: repeat_channels +owner: imgteam +homepage_url: https://github.com/bmcv +remote_repository_url: https://github.com/BMCV/galaxy-image-analysis/tree/master/tools/repeat_channels/ diff --git a/tools/repeat_channels/creators.xml b/tools/repeat_channels/creators.xml new file mode 120000 index 00000000..5d2b71e0 --- /dev/null +++ b/tools/repeat_channels/creators.xml @@ -0,0 +1 @@ +../../macros/creators.xml \ No newline at end of file diff --git a/tools/repeat_channels/repeat_channels.py b/tools/repeat_channels/repeat_channels.py new file mode 100644 index 00000000..2ce499c1 --- /dev/null +++ b/tools/repeat_channels/repeat_channels.py @@ -0,0 +1,19 @@ +import argparse + +import giatools.io +import numpy as np +import skimage.io + + +if __name__ == '__main__': + + parser = argparse.ArgumentParser() + parser.add_argument('input', type=str) + parser.add_argument('count', type=int) + parser.add_argument('output', type=str) + args = parser.parse_args() + + im = giatools.io.imread(args.input) + im = np.squeeze(im) + im = np.dstack([im] * args.count) + skimage.io.imsave(args.output, im) diff --git a/tools/repeat_channels/repeat_channels.xml b/tools/repeat_channels/repeat_channels.xml new file mode 100644 index 00000000..6350e499 --- /dev/null +++ b/tools/repeat_channels/repeat_channels.xml @@ -0,0 +1,61 @@ + + with NumPy + + creators.xml + tests.xml + 1.26.4 + 0 + + + + + + operation_3443 + + + galaxy_image_analysis + + + numpy + scikit-image + giatools + + + + + + + + + + + + + + + + + + + + **Convert single-channel to multi-channel image.** + + This tools converts a single-channel image to a multi-channel image by repeating the channel multiple times. + + + + 10.1038/s41586-020-2649-2 + + diff --git a/tools/repeat_channels/test-data/input1.tif b/tools/repeat_channels/test-data/input1.tif new file mode 100644 index 0000000000000000000000000000000000000000..4ddc063fb22beb31008acd56a3a059537c77b47a GIT binary patch literal 70481 zcmeHQON(7a5WbVBC`drT2)dY%m52xmy6_)l=~`U4$Y8)lKsO@(rtJJRE?xQ`#&hqS zM?b2ntGcV|oN;Pk=62WXdvu>WlQ6~?FFrrLdpez-oK9D7ovxWd^W%B_{fAelPp;m+%>R4p{d8XcGp#>M zdcT_HzdyzPoj%VWe?0&7=bv7`eE!|DAHM$fn=hVCUw-`aE|q*evrIpKdv$Yj^XiwE zU%vi5sfuMd5DtU`;XpVL4uk{YKsXQ%gahF~I1mnm1K~h85DtU`;XpVL4uk{YKsXQ% zgahF~I1mnm1K~h85DtU`;XpVL4jkKo>*ZsjnJkY@T94iJ^<~zgynfY#I_9KWF&;Ul zf?-y;U_3JndZ+=oPEO`fQo6}-l(uWS;g8bTmdLF*ilQzaT#>B0E(V8aV#$*f9YU3u zghU~~R!n2}2EI07VWBKsGw@PO>uc^hCY5t1JYD_HoQRuNb^OqDglHv zl##XEq@cVtOCGaG#X=&OZ*`jLB2~E89|zlCS?aKuSS8-2^%L!NHi&zChS0w!-&lqlN+&(7p;WnD=(+m zJSZcmw@V8nDC4P|{D`F;6uN;E6daY4%97Vp=m#=_{R@?H2j&i6BPcXF*Da9UNa3qr z2?~tPvGw#95(Expg#EKY{TDCVMi8DiQ~f8+@5D(cJAnhWGkiG%l_(8eBTyJtVn83e z6(#b}j6i?Bd~il!P8`VykMA4!cMer2&?k_WU_a?Yg$S1;8R2s!;DIH)8nFm>3QnHMbdXLiI*y7~$f?y)a@YCvrO z+G|=m2CP$RfL5eO#&}Q7YL%d~r~&B6xTMYr6)he8>y&Cf8R!(D(N^(VCFm@w`9wfN zPxp+HmyY~oN(q4PyEUjZmb?-PI?ECO+pDM<7*g`mQJ+pJ5y1U`0;SfHRw_YfT_Qkx zB{3soN?JPNvneG+y&n;v)?3iZBuCG=qadeH>xyc{I1-oDY(lZ;H-pdPpp+51HE zL~n0zn>C6B+bJQ(s2bkTnoq{$gR2u8HC4sfuobR#mKPs9uf)pC@aM|Rl^L*M#GMbG zSHj(h`Hg}$V)4Q8N~}g?$7Z{kFi9U)8$55s`irNw+KcIw5s3}|eTCjTy>nUwB^hMplTap%1_Fqvc&ZlEL+vU^h68utp)E9&rhTGC%{Ona7e(+D+CW2DIwTs@eA5nkaR^_jBpOcABSTX2 zO?t@1F?_XBXgEio48_eg=OY(KaTQB|;S9Yp1Ub)?ms}jjQ!S2#^YhE#>>M+Ga&aU_ zxhNFQ&NGA3^GkTj#j*VKVn{eQ-wejjE$%B9M{^U50O8EMGYCPiu(wiC(!^5#cGEfz|bkQgIE&MNp=N8lG-I%QFICHBDDePBD@4?aM~wbl62Vb zBeaR?pgf0YGTN;m=V`s$O(p}_T6;R5L1)L3l&S4{N0B^eTlwpB9+_RMR<4$dT@`Y{ zEe)7wbE)iHXYIt!@+9!4R!E5KUu$Q@{@P>=telXsI6}3F6Gspx=b&$eoWnsnbgeju zs6HBcR`lT?s7u9)1L+x|GUmky@&SAM%s8MB4N4+2Gyo4hgXPAd6)2LU%}@loFQXPi zX1+W88&dbhso)t7gahF~I1mnm1K~h85DtU`;XpVL4uk{YKsXQ%gahF~I1mnm1K~h8 F@E>a&-+=%C literal 0 HcmV?d00001 diff --git a/tools/repeat_channels/test-data/input1_c3.tif b/tools/repeat_channels/test-data/input1_c3.tif new file mode 100644 index 0000000000000000000000000000000000000000..b3307345e669603ef87cc6e1f88dffc088b64781 GIT binary patch literal 210947 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 literal 0 HcmV?d00001 diff --git a/tools/repeat_channels/tests.xml b/tools/repeat_channels/tests.xml new file mode 120000 index 00000000..e20d710a --- /dev/null +++ b/tools/repeat_channels/tests.xml @@ -0,0 +1 @@ +../../macros/tests.xml \ No newline at end of file