PiNS / scripts /DLCS24_KNN_2mm_Extend_Radiomics.sh
ft42's picture
Upload 21 files
7f24887 verified
#!/bin/bash
# ===# Create output directory and set proper permissions
echo "Setting up output directories and permissions..."
docker exec nodule_seg_pipeline mkdir -p /app/demofolder/output/DLCS24_KNN_2mm_Extend_Seg
docker exec nodule_seg_pipeline chmod -R 777 /app/demofolder/output/
echo "Installing missing Python packages if needed..."
docker exec nodule_seg_pipeline pip install opencv-python-headless --quiet > /dev/null 2>&1 || true
echo "Docker container is running with write permissions set"===================
# Docker Container Activation
# ============================
echo "Starting Docker container..."
cd "$(dirname "$0")/.." # Go to project root
# Remove existing container if it exists
docker rm -f nodule_seg_pipeline 2>/dev/null || true
# Start container using existing medical imaging image
docker run -d --name nodule_seg_pipeline \
-v "$(pwd):/app" \
-w /app \
ft42/pins:latest \
tail -f /dev/null
# Create output directory and set proper permissions
echo "Setting up output directories and permissions..."
docker exec nodule_seg_pipeline mkdir -p /app/demofolder/output/DLCS24_KNN_2mm_Extend_RadiomicsSeg
docker exec nodule_seg_pipeline chmod -R 777 /app/demofolder/output/
echo "Docker container is running with write permissions set"
# ============================
# Configuration Variables
# ============================
# Define paths
PYTHON_SCRIPT="/app/scr/candidateSeg_radiomicsExtractor_pipiline.py" # Path inside container
PARAMS_JSON="/app/scr/Pyradiomics_feature_extarctor_pram.json" # Path inside container
DATASET_NAME="DLCSD24"
RAW_DATA_PATH="/app/demofolder/data/DLCS24/"
CSV_SAVE_PATH="/app/demofolder/output/"
DATASET_CSV="/app/demofolder/data/DLCSD24_Annotations_N2.csv"
NIFTI_CLM_NAME="ct_nifti_file"
UNIQUE_ANNOTATION_ID="nodule_id" # Leave empty or remove if not in CSV
MALIGNANT_LBL="Malignant_lbl"
COORD_X="coordX"
COORD_Y="coordY"
COORD_Z="coordZ"
W="w"
H="h"
D="d"
SEG_ALG="knn" # Choose from: gmm, knn, fcm, otsu
EXPANSION_MM=2.0 # Set the expansion in millimeters
SAVE_NIFTI_PATH="/app/demofolder/output/DLCS24_KNN_2mm_Extend_RadiomicsSeg/"
SAVE_MASK_FLAG="--save_the_generated_mask" # Remove if you don't want to save masks
USE_EXPAND_FLAG="--use_expand" # Include if you want to use expansion
EXTRACT_RADIOMICS_FLAG="--extract_radiomics" # Include if you want to extract radiomics "--extract_radiomics"
# ============================
# Run the Python script in Docker
# ============================
echo "Running segmentation in Docker container..."
docker exec nodule_seg_pipeline python3 "$PYTHON_SCRIPT" \
--dataset_name "$DATASET_NAME" \
--raw_data_path "$RAW_DATA_PATH" \
--csv_save_path "$CSV_SAVE_PATH" \
--dataset_csv "$DATASET_CSV" \
--nifti_clm_name "$NIFTI_CLM_NAME" \
--unique_Annotation_id "$UNIQUE_ANNOTATION_ID" \
--Malignant_lbl "$MALIGNANT_LBL" \
--coordX "$COORD_X" \
--coordY "$COORD_Y" \
--coordZ "$COORD_Z" \
--w "$W" \
--h "$H" \
--d "$D" \
--seg_alg "$SEG_ALG" \
--expansion_mm "$EXPANSION_MM" \
--params_json "$PARAMS_JSON" \
--save_nifti_path "$SAVE_NIFTI_PATH" \
$USE_EXPAND_FLAG \
$EXTRACT_RADIOMICS_FLAG \
$SAVE_MASK_FLAG
echo "✅ Segmentation completed! Check demofolder/output/ directory for results."