All Downloads are FREE. Search and download functionalities are using the official Maven repository.

io.github.mianalysis.mia.module.objects.relate.mergeobjects.CombineObjectSets Maven / Gradle / Ivy

Go to download

ModularImageAnalysis (MIA) is an ImageJ plugin which provides a modular framework for assembling image and object analysis workflows. Detected objects can be transformed, filtered, measured and related. Analysis workflows are batch-enabled by default, allowing easy processing of high-content datasets.

There is a newer version: 1.6.12
Show newest version
package io.github.mianalysis.mia.module.objects.relate.mergeobjects;

import java.util.LinkedHashMap;

import org.scijava.Priority;
import org.scijava.plugin.Plugin;

import com.drew.lang.annotations.NotNull;

import io.github.mianalysis.mia.MIA;
import io.github.mianalysis.mia.module.Categories;
import io.github.mianalysis.mia.module.Category;
import io.github.mianalysis.mia.module.Module;
import io.github.mianalysis.mia.module.Modules;
import io.github.mianalysis.mia.object.Measurement;
import io.github.mianalysis.mia.object.Obj;
import io.github.mianalysis.mia.object.ObjMetadata;
import io.github.mianalysis.mia.object.Objs;
import io.github.mianalysis.mia.object.Workspace;
import io.github.mianalysis.mia.object.parameters.BooleanP;
import io.github.mianalysis.mia.object.parameters.ChoiceP;
import io.github.mianalysis.mia.object.parameters.InputObjectsP;
import io.github.mianalysis.mia.object.parameters.Parameters;
import io.github.mianalysis.mia.object.parameters.SeparatorP;
import io.github.mianalysis.mia.object.parameters.abstrakt.Parameter;
import io.github.mianalysis.mia.object.parameters.objects.OutputObjectsP;
import io.github.mianalysis.mia.object.refs.ObjMeasurementRef;
import io.github.mianalysis.mia.object.refs.ObjMetadataRef;
import io.github.mianalysis.mia.object.refs.collections.ImageMeasurementRefs;
import io.github.mianalysis.mia.object.refs.collections.MetadataRefs;
import io.github.mianalysis.mia.object.refs.collections.ObjMeasurementRefs;
import io.github.mianalysis.mia.object.refs.collections.ObjMetadataRefs;
import io.github.mianalysis.mia.object.refs.collections.ParentChildRefs;
import io.github.mianalysis.mia.object.refs.collections.PartnerRefs;
import io.github.mianalysis.mia.object.system.Status;

/**
 * Created by sc13967 on 31/01/2018.
 */

/**
 * Combines the objects from two collections stored in the workspace. Either the
 * objects from one collection can be added to the other or they can both be
 * combined into a new collection, which is added to the workspace.
*
* Note: Any objects added to another collection (either the "other" object * collection or to a new collection) are duplicates of the original objects. * These duplicates contain the same spatial and temporal information as well as * any relationship connections and measurements. The original objects are * unaffected by this module. */ @Plugin(type = Module.class, priority = Priority.LOW, visible = true) public class CombineObjectSets extends Module { /** * */ public static final String INPUT_SEPARATOR = "Objects input"; /** * First of two object collections to combine. Depending on the choice for * parameter "Output mode", this collection may be updated to include the * objects from the second collection ("Input objects 2"). */ public static final String INPUT_OBJECTS_1 = "Input objects 1"; /** * Second of two object collections to combine. Depending on the choice for * parameter "Output mode", this collection may be updated to include the * objects from the first collection ("Input objects 2"). */ public static final String INPUT_OBJECTS_2 = "Input objects 2"; /** * */ public static final String ALLOW_MISSING_OBJECTS = "Allow missing objects"; /** * */ public static final String OUTPUT_SEPARATOR = "Objects output"; /** * Controls where the combined object collections are stored:
*
    *
  • "Add set objects 2 to set 1" Duplicates of all objects in the second * collection ("Input objects 2") are made and added to the first collection * ("Input objects 1").
  • *
  • "Add set objects 1 to set 2" Duplicates of all objects in the first * collection ("Input objects 1") are made and added to the second collection * ("Input objects 1").
  • *
  • "Create new object set". Duplicates of all objects in the first ("Input * objects 1") and second ("Input objects 2") collections are made and added to * a new collection with name specified by "Output objects"
  • *
*/ public static final String OUTPUT_MODE = "Output mode"; /** * Name of the combined output collection to be added to the workspace if * "Output mode" is set to "Create new object set". */ public static final String OUTPUT_OBJECTS = "Output objects"; public interface OutputModes { String ADD_TO_OBJECTS_1 = "Add set objects 2 to set 1"; String ADD_TO_OBJECTS_2 = "Add set objects 1 to set 2"; String CREATE_NEW = "Create new object set"; String[] ALL = new String[] { ADD_TO_OBJECTS_1, ADD_TO_OBJECTS_2, CREATE_NEW }; } public CombineObjectSets(Modules modules) { super("Combine object sets", modules); } public static void addObjects(Objs targetObjects, Objs sourceObjects) { for (Obj obj : sourceObjects.values()) { Obj newObj = targetObjects.createAndAddNewObject(obj.getVolumeType()); newObj.setCoordinateSet(obj.getCoordinateSet().duplicate()); newObj.setT(obj.getT()); // Transferring parents LinkedHashMap parents = obj.getParents(false); newObj.setParents(parents); for (Obj parent : parents.values()) parent.addChild(newObj); // Transferring children LinkedHashMap children = obj.getChildren(); newObj.setChildren(children); for (Objs childSet : children.values()) for (Obj child : childSet.values()) child.addParent(newObj); // Transferring partners LinkedHashMap partners = obj.getPartners(); newObj.setPartners(partners); for (Objs partnerSet : partners.values()) for (Obj partner : partnerSet.values()) partner.addPartner(newObj); // Transferring measurements LinkedHashMap measurements = obj.getMeasurements(); newObj.setMeasurements(measurements); // Transferring measurements LinkedHashMap metadata = obj.getMetadata(); newObj.setMetadata(metadata); } } @Override public Category getCategory() { return Categories.OBJECTS_RELATE_MERGE; } @Override public String getVersionNumber() { return "1.0.0"; } @Override public String getDescription() { return "Combines the objects from two collections stored in the workspace. Either the objects from one collection can be added to the other or they can both be combined into a new collection, which is added to the workspace.

Note: Any objects added to another collection (either the \"other\" object collection or to a new collection) are duplicates of the original objects. These duplicates contain the same spatial and temporal information as well as any relationship connections and measurements. The original objects are unaffected by this module."; } @Override public Status process(Workspace workspace) { // Getting parameters String inputObjects1Name = parameters.getValue(INPUT_OBJECTS_1, workspace); String inputObjects2Name = parameters.getValue(INPUT_OBJECTS_2, workspace); boolean allowMissingObjects = parameters.getValue(ALLOW_MISSING_OBJECTS, workspace); String outputMode = parameters.getValue(OUTPUT_MODE, workspace); String outputObjectsName = parameters.getValue(OUTPUT_OBJECTS, workspace); // Getting objects Objs inputObjects1 = workspace.getObjects(inputObjects1Name); Objs inputObjects2 = workspace.getObjects(inputObjects2Name); if (allowMissingObjects) outputMode = OutputModes.CREATE_NEW; // Doing object merging switch (outputMode) { case OutputModes.ADD_TO_OBJECTS_1: addObjects(inputObjects1, inputObjects2); if (showOutput) inputObjects1.convertToImageIDColours().show(); break; case OutputModes.ADD_TO_OBJECTS_2: addObjects(inputObjects2, inputObjects1); if (showOutput) inputObjects2.convertToImageIDColours().show(); break; case OutputModes.CREATE_NEW: Objs exampleObjects = inputObjects1; if (exampleObjects == null) exampleObjects = inputObjects2; if (exampleObjects == null) return Status.PASS; Objs outputObjects = new Objs(outputObjectsName, exampleObjects); if (inputObjects1 != null) addObjects(outputObjects, inputObjects1); if (inputObjects2 != null) addObjects(outputObjects, inputObjects2); // Adding the combined objects to the workspace workspace.addObjects(outputObjects); if (showOutput) outputObjects.convertToImageIDColours().show(); break; } return Status.PASS; } @Override protected void initialiseParameters() { parameters.add(new SeparatorP(INPUT_SEPARATOR, this)); parameters.add(new CustomInputObjectsP(INPUT_OBJECTS_1, this)); parameters.add(new CustomInputObjectsP(INPUT_OBJECTS_2, this)); parameters.add(new BooleanP(ALLOW_MISSING_OBJECTS, this, false)); parameters.add(new SeparatorP(OUTPUT_SEPARATOR, this)); parameters.add(new ChoiceP(OUTPUT_MODE, this, OutputModes.CREATE_NEW, OutputModes.ALL)); parameters.add(new OutputObjectsP(OUTPUT_OBJECTS, this)); addParameterDescriptions(); } @Override public Parameters updateAndGetParameters() { Workspace workspace = null; Parameters returnedParameters = new Parameters(); returnedParameters.add(parameters.get(INPUT_SEPARATOR)); returnedParameters.add(parameters.get(INPUT_OBJECTS_1)); returnedParameters.add(parameters.get(INPUT_OBJECTS_2)); returnedParameters.add(parameters.get(ALLOW_MISSING_OBJECTS)); boolean allowMissingObjects = parameters.getValue(ALLOW_MISSING_OBJECTS, workspace); ((CustomInputObjectsP) parameters.get(INPUT_OBJECTS_1)).setAllowMissingObjects(allowMissingObjects); ((CustomInputObjectsP) parameters.get(INPUT_OBJECTS_2)).setAllowMissingObjects(allowMissingObjects); returnedParameters.add(parameters.get(OUTPUT_SEPARATOR)); if ((boolean) parameters.getValue(ALLOW_MISSING_OBJECTS, null)) { returnedParameters.add(parameters.get(OUTPUT_OBJECTS)); } else { returnedParameters.add(parameters.get(OUTPUT_MODE)); switch ((String) parameters.getValue(OUTPUT_MODE, workspace)) { case OutputModes.CREATE_NEW: returnedParameters.add(parameters.get(OUTPUT_OBJECTS)); break; } } return returnedParameters; } @Override public ImageMeasurementRefs updateAndGetImageMeasurementRefs() { return null; } @Override public ObjMeasurementRefs updateAndGetObjectMeasurementRefs() { Workspace workspace = null; ObjMeasurementRefs returnedRefs = new ObjMeasurementRefs(); // If the filtered objects are to be moved to a new class, assign them the // measurements they've lost String outputObjectsName = parameters.getValue(OUTPUT_OBJECTS, workspace); String inputObjectsName = parameters.getValue(INPUT_OBJECTS_1, workspace); ObjMeasurementRefs references = modules.getObjectMeasurementRefs(inputObjectsName, this); for (ObjMeasurementRef reference : references.values()) returnedRefs.add(objectMeasurementRefs.getOrPut(reference.getName()).setObjectsName(outputObjectsName)); inputObjectsName = parameters.getValue(INPUT_OBJECTS_2, workspace); references = modules.getObjectMeasurementRefs(inputObjectsName, this); for (ObjMeasurementRef reference : references.values()) returnedRefs.add(objectMeasurementRefs.getOrPut(reference.getName()).setObjectsName(outputObjectsName)); return returnedRefs; } @Override public ObjMetadataRefs updateAndGetObjectMetadataRefs() { Workspace workspace = null; ObjMetadataRefs returnedRefs = new ObjMetadataRefs(); String outputObjectsName = parameters.getValue(OUTPUT_OBJECTS, workspace); String inputObjectsName = parameters.getValue(INPUT_OBJECTS_1, workspace); ObjMetadataRefs references = modules.getObjectMetadataRefs(inputObjectsName, this); for (ObjMetadataRef reference : references.values()) returnedRefs.add(objectMetadataRefs.getOrPut(reference.getName()).setObjectsName(outputObjectsName)); inputObjectsName = parameters.getValue(INPUT_OBJECTS_2, workspace); references = modules.getObjectMetadataRefs(inputObjectsName, this); for (ObjMetadataRef reference : references.values()) returnedRefs.add(objectMetadataRefs.getOrPut(reference.getName()).setObjectsName(outputObjectsName)); return returnedRefs; } @Override public MetadataRefs updateAndGetMetadataReferences() { return null; } @Override public ParentChildRefs updateAndGetParentChildRefs() { Workspace workspace = null; // Where necessary, redirect relationships ParentChildRefs returnedRefs = new ParentChildRefs(); String outputObjectsName = parameters.getValue(OUTPUT_OBJECTS, workspace); ParentChildRefs currentRefs = modules.getParentChildRefs(this); String inputObjectsName = parameters.getValue(INPUT_OBJECTS_1, workspace); String[] childNames = currentRefs.getChildNames(inputObjectsName, true); for (String childName : childNames) returnedRefs.add(parentChildRefs.getOrPut(outputObjectsName, childName)); String[] parentNames = currentRefs.getParentNames(inputObjectsName, true); for (String parentName : parentNames) returnedRefs.add(parentChildRefs.getOrPut(parentName, outputObjectsName)); inputObjectsName = parameters.getValue(INPUT_OBJECTS_2, workspace); childNames = currentRefs.getChildNames(inputObjectsName, true); for (String childName : childNames) returnedRefs.add(parentChildRefs.getOrPut(outputObjectsName, childName)); parentNames = currentRefs.getParentNames(inputObjectsName, true); for (String parentName : parentNames) returnedRefs.add(parentChildRefs.getOrPut(parentName, outputObjectsName)); return returnedRefs; } @Override public PartnerRefs updateAndGetPartnerRefs() { return null; } @Override public boolean verify() { return true; } class CustomInputObjectsP extends InputObjectsP { private boolean allowMissingObjects = false; public CustomInputObjectsP(String name, Module module) { super(name, module); } public CustomInputObjectsP(String name, Module module, @NotNull String choice) { super(name, module); this.choice = choice; } public CustomInputObjectsP(String name, Module module, @NotNull String choice, String description) { super(name, module, description); this.choice = choice; } @Override public boolean verify() { if (allowMissingObjects) return true; else return super.verify(); } @Override public boolean isValid() { if (allowMissingObjects) return true; else return super.isValid(); } @Override public T duplicate(Module newModule) { CustomInputObjectsP newParameter = new CustomInputObjectsP(name, newModule, getRawStringValue(), getDescription()); newParameter.setNickname(getNickname()); newParameter.setVisible(isVisible()); newParameter.setExported(isExported()); newParameter.setAllowMissingObjects(allowMissingObjects); return (T) newParameter; } public boolean isAllowMissingObjects() { return allowMissingObjects; } public void setAllowMissingObjects(boolean allowMissingObjects) { this.allowMissingObjects = allowMissingObjects; } } void addParameterDescriptions() { parameters.get(INPUT_OBJECTS_1) .setDescription("First of two object collections to combine. Depending on the choice for parameter \"" + OUTPUT_MODE + "\", this collection may be updated to include the objects from the second collection (\"" + INPUT_OBJECTS_2 + "\")."); parameters.get(INPUT_OBJECTS_2) .setDescription("Second of two object collections to combine. Depending on the choice for parameter \"" + OUTPUT_MODE + "\", this collection may be updated to include the objects from the first collection (\"" + INPUT_OBJECTS_2 + "\")."); parameters.get(OUTPUT_MODE).setDescription("Controls where the combined object collections are stored:
    " + "
  • \"" + OutputModes.ADD_TO_OBJECTS_1 + "\" Duplicates of all objects in the second collection (\"" + INPUT_OBJECTS_2 + "\") are made and added to the first collection (\"" + INPUT_OBJECTS_1 + "\").
  • " + "
  • \"" + OutputModes.ADD_TO_OBJECTS_2 + "\" Duplicates of all objects in the first collection (\"" + INPUT_OBJECTS_1 + "\") are made and added to the second collection (\"" + INPUT_OBJECTS_1 + "\").
  • " + "
  • \"" + OutputModes.CREATE_NEW + "\". Duplicates of all objects in the first (\"" + INPUT_OBJECTS_1 + "\") and second (\"" + INPUT_OBJECTS_2 + "\") collections are made and added to a new collection with name specified by \"" + OUTPUT_OBJECTS + "\"
"); parameters.get(OUTPUT_OBJECTS) .setDescription("Name of the combined output collection to be added to the workspace if \"" + OUTPUT_MODE + "\" is set to \"" + OutputModes.CREATE_NEW + "\"."); } }




© 2015 - 2024 Weber Informatics LLC | Privacy Policy