Mercurial > repos > imgteam > 2d_feature_extraction
diff 2d_feature_extraction.py @ 4:0a53256b48c6 draft
planemo upload for repository https://github.com/BMCV/galaxy-image-analysis/tree/master/tools/2d_feature_extraction/ commit 6b687746bdb3d5d1fb11ecffd6dd1bf42dc2c38d
author | imgteam |
---|---|
date | Fri, 10 Nov 2023 14:23:12 +0000 |
parents | 5791a7f65275 |
children | 2436a8807ad1 |
line wrap: on
line diff
--- a/2d_feature_extraction.py Wed Dec 18 05:00:56 2019 -0500 +++ b/2d_feature_extraction.py Fri Nov 10 14:23:12 2023 +0000 @@ -1,17 +1,18 @@ import argparse + import numpy as np import pandas as pd +import skimage.feature import skimage.io import skimage.measure -import skimage.feature +import skimage.morphology import skimage.segmentation -import skimage.morphology -#TODO make importable by python script +# TODO make importable by python script parser = argparse.ArgumentParser(description='Extract Features 2D') -#TODO create factory for boilerplate code +# TODO create factory for boilerplate code features = parser.add_argument_group('compute features') features.add_argument('--all', dest='all_features', action='store_true') features.add_argument('--label', dest='add_label', action='store_true') @@ -19,7 +20,7 @@ features.add_argument('--max_intensity', dest='max_intensity', action='store_true') features.add_argument('--mean_intensity', dest='mean_intensity', action='store_true') features.add_argument('--min_intensity', dest='min_intensity', action='store_true') -features.add_argument('--moments_hu', dest='moments_hu', action='store_true') +features.add_argument('--moments_hu', dest='moments_hu', action='store_true') features.add_argument('--centroid', dest='centroid', action='store_true') features.add_argument('--bbox', dest='bbox', action='store_true') features.add_argument('--area', dest='area', action='store_true') @@ -41,13 +42,13 @@ parser.add_argument('--label_file_binary', dest='label_file_binary', action='store_true') parser.add_argument('--raw', dest='raw_file', type=argparse.FileType('r'), - help='Original input file', required=False) + help='Original input file', required=False) parser.add_argument('label_file', type=argparse.FileType('r'), - help='Label input file') + help='Label input file') parser.add_argument('output_file', type=argparse.FileType('w'), - help='Tabular output file') + help='Tabular output file') args = parser.parse_args() - + label_file_binary = args.label_file_binary label_file = args.label_file.name out_file = args.output_file.name @@ -70,7 +71,7 @@ df['image'] = df['it'].map(lambda ait: regions[ait].image.astype(np.float).tolist()) df['intensity_image'] = df['it'].map(lambda ait: regions[ait].intensity_image.astype(np.float).tolist()) -#TODO no matrix features, but split in own rows? +# TODO no matrix features, but split in own rows? if args.add_label or args.all_features: df['label'] = df['it'].map(lambda ait: regions[ait].label) @@ -119,7 +120,7 @@ if args.convexity or args.all_features: perimeter = df['it'].map(lambda ait: regions[ait].perimeter) area = df['it'].map(lambda ait: regions[ait].area) - df['convexity'] = area/(perimeter*perimeter) + df['convexity'] = area / (perimeter * perimeter) del df['it'] df.to_csv(out_file, sep='\t', line_terminator='\n', index=False)