# HG changeset patch # User lldelisle # Date 1734076708 0 # Node ID 9be687213bc9ab8df03b9f0dbe2a45ec652bbb30 # Parent a02156aa8bda3d5ec91199d081bab7d83c754238 planemo upload for repository https://github.com/lldelisle/tools-lldelisle/tree/master/tools/max_projections_stack_and_upload_omero commit 39c8ae77d15d77ddcd8a0bb70f46d1be1531e9cc diff -r a02156aa8bda -r 9be687213bc9 CHANGELOG.md --- /dev/null Thu Jan 01 00:00:00 1970 +0000 +++ b/CHANGELOG.md Fri Dec 13 07:58:28 2024 +0000 @@ -0,0 +1,11 @@ +# CHANGELOG + +## 20241213 + +- Remove unused input plateName in wrapper. +- Do not break if there is an issue with the nb of slices in one image but try to get the Greys +- Fix the omero path to create projects/datasets + +## 20241212 + +First release \ No newline at end of file diff -r a02156aa8bda -r 9be687213bc9 max_projections_stack_and_upload_omero.xml --- a/max_projections_stack_and_upload_omero.xml Thu Dec 12 12:42:20 2024 +0000 +++ b/max_projections_stack_and_upload_omero.xml Fri Dec 13 07:58:28 2024 +0000 @@ -1,7 +1,7 @@ And upload to omero - 20241212 + 20241213 0 @@ -64,7 +64,6 @@ ^[a-zA-Z0-9._-]*$ '..' not in value - diff -r a02156aa8bda -r 9be687213bc9 stack_max_projs.groovy --- a/stack_max_projs.groovy Thu Dec 12 12:42:20 2024 +0000 +++ b/stack_max_projs.groovy Fri Dec 13 07:58:28 2024 +0000 @@ -29,7 +29,7 @@ */ // Version number = date of last modif -VERSION = "20241212" +VERSION = "20241213" /** * ***************************************************************************************************************** @@ -97,9 +97,9 @@ " filter=" + fluo_pattern_list[i] ) ) + // println samplesMap.get(unique_identifier).get(fluo_channels_list[i]).getDimensions() if (!GraphicsEnvironment.isHeadless()){ - samplesMap.get(unique_identifier).get( - fluo_channels_list[i]).show() + samplesMap.get(unique_identifier).get(fluo_channels_list[i]).show() } } } @@ -107,9 +107,9 @@ // It is easy as all images are used println "Processing " + unique_identifier + " Greys" samplesMap.get(unique_identifier).put(final_color, FolderOpener.open(current_directory.getAbsolutePath())) + // println samplesMap.get(unique_identifier).get(final_color).getDimensions() if (!GraphicsEnvironment.isHeadless()){ - samplesMap.get(unique_identifier).get( - final_color).show() + samplesMap.get(unique_identifier).get(final_color).show() } } } @@ -120,27 +120,55 @@ Map channelsMap = samplesMap.get(unique_identifier) ArrayList channels = [] ArrayList current_images = [] + int ref_nT = 0 + boolean all_compatibles = true for(String channel : channelsMap.keySet()){ channels.add(channel) current_images.add(channelsMap.get(channel)) + if (ref_nT == 0) { + ref_nT = channelsMap.get(channel).nSlices + } else { + if (ref_nT != channelsMap.get(channel).nSlices) { + all_compatibles = false + } + } } - // Get number of time: - int nT = current_images[0].nSlices - - // Merge all - ImagePlus merged_imps = Concatenator.run(current_images as ImagePlus[]) - // Re-order to make a multi-channel, time-lapse image - ImagePlus final_imp - if (channels.size() == 1 && nT == 1) { - final_imp = merged_imps + + if (all_compatibles) { + // Merge all + ImagePlus merged_imps = Concatenator.run(current_images as ImagePlus[]) + // Re-order to make a multi-channel, time-lapse image + ImagePlus final_imp + if (channels.size() == 1 && nT == 1) { + final_imp = merged_imps + } else { + try { + final_imp = HyperStackConverter.toHyperStack(merged_imps, channels.size() , 1, ref_nT, "xytcz", "Color") + // set LUTs + (0..channels.size()-1).each{ + final_imp.setC(it + 1) + IJ.run(final_imp, channels[it], "") + final_imp.resetDisplayRange() + } + } catch(Exception e) { + println "Could not create the hyperstack for " + unique_identifier + ": " + e + continue + } + } } else { - final_imp = HyperStackConverter.toHyperStack(merged_imps, channels.size() , 1, nT, "xytcz", "Color") - } - // set LUTs - (0..channels.size()-1).each{ - final_imp.setC(it + 1) - IJ.run(final_imp, channels[it], "") + println "Not all channels have the same number of slices:" + (0..channels.size()-1).each{ + println "Channel " + channels[it] + " has " + current_images[it].getDimensions() + " whCZT." + } + if (channelsMap.containsKey("Greys")) { + println "Will keep only Greys channel" + final_imp = channelsMap.get("Greys") + } else { + println "Will keep only " + channels[0] + " channel" + final_imp = current_images[0] + IJ.run(final_imp, channels[0], "") + } final_imp.resetDisplayRange() } // Save to tiff diff -r a02156aa8bda -r 9be687213bc9 upload_omero.sh --- a/upload_omero.sh Thu Dec 12 12:42:20 2024 +0000 +++ b/upload_omero.sh Fri Dec 13 07:58:28 2024 +0000 @@ -8,13 +8,13 @@ if [ "$to_create" = "both" ]; then # Create a project: - project_name_or_id=$(${omero_path} obj -s ${omero_server} -u ${omero_user} -w ${omero_password} new Project name="${project_name_or_id}" | awk -F ":" 'END{print $NF}') + project_name_or_id=$(omero obj -s ${omero_server} -u ${omero_user} -w ${omero_password} new Project name="${project_name_or_id}" | awk -F ":" 'END{print $NF}') echo "Just created the new project ${project_name_or_id}" fi if [ "$to_create" = "both" ] || [ "$to_create" = "dataset" ]; then - dataset_name_or_id=$(${omero_path} obj -s ${omero_server} -u ${omero_user} -w ${omero_password} new Dataset name="${dataset_name_or_id}" | awk -F ":" 'END{print $NF}') + dataset_name_or_id=$(omero obj -s ${omero_server} -u ${omero_user} -w ${omero_password} new Dataset name="${dataset_name_or_id}" | awk -F ":" 'END{print $NF}') echo "Just created the new dataset ${dataset_name_or_id}" - ${omero_path} obj -s ${omero_server} -u ${omero_user} -w ${omero_password} new ProjectDatasetLink parent=Project:${project_name_or_id} child=Dataset:${dataset_name_or_id} + omero obj -s ${omero_server} -u ${omero_user} -w ${omero_password} new ProjectDatasetLink parent=Project:${project_name_or_id} child=Dataset:${dataset_name_or_id} fi echo "Start upload" omero import -s ${omero_server} -u ${omero_user} -w ${omero_password} --depth 1 -T Dataset:id:"${dataset_name_or_id}" output 2>&1