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

org.micromanager.acqj.util.AcqEventModules Maven / Gradle / Ivy

package org.micromanager.acqj.util;

import java.util.Iterator;
import java.util.List;
import java.util.function.Function;
import java.util.stream.Collectors;
import java.util.stream.Stream;

import org.micromanager.acqj.main.AcqEngMetadata;
import org.micromanager.acqj.main.AcquisitionEvent;
import org.micromanager.acqj.util.xytiling.XYStagePosition;
import org.micromanager.acqj.internal.Engine;

/**
 * A utility class with multiple "modules" functions for creating common
 * acquisition functions that can be combined to encode complex behaviors
 *
 * @author henrypinkard
 */
public class AcqEventModules {

   public static Function> zStack(int startSliceIndex, int stopSliceIndex, double zStep, double zOrigin) {
      return (AcquisitionEvent event) -> {
         return new Iterator() {

            private int zIndex_ = startSliceIndex;

            @Override
            public boolean hasNext() {
               return zIndex_ < stopSliceIndex;
            }

            @Override
            public AcquisitionEvent next() {
               double zPos = zIndex_ * zStep + zOrigin;
               AcquisitionEvent sliceEvent = event.copy();
               //Do plus equals here in case z positions have been modified by another function (e.g. channel specific focal offsets)
               sliceEvent.setZ(zIndex_,
                       (sliceEvent.getZPosition() == null ? 0.0 : sliceEvent.getZPosition()) + zPos);
               zIndex_++;
               return sliceEvent;
            }
         };
      };
   }

   public static Function> timelapse(int numTimePoints, double interval_ms) {
      return (AcquisitionEvent event) -> {
         return new Iterator() {

            int frameIndex_ = 0;

            @Override
            public boolean hasNext() {
               if (frameIndex_ == 0) {
                  return true;
               }
               if (frameIndex_ < numTimePoints) {
                  return true;
               }
               return false;
            }

            @Override
            public AcquisitionEvent next() {
               AcquisitionEvent timePointEvent = event.copy();

               timePointEvent.setMinimumStartTime((long) (interval_ms * frameIndex_));
               
               timePointEvent.setTimeIndex(frameIndex_);
               frameIndex_++;

               return timePointEvent;
            }
         };
      };
   }

   /**
    * Make an iterator for events for each active channel
    *
    * @param channelList 
    * @return
    */
   public static Function> channels(List channelList) {
      return (AcquisitionEvent event) -> {
         return new Iterator() {
            int index = 0;

            @Override
            public boolean hasNext() {
               return index < channelList.size();
            }

            @Override
            public AcquisitionEvent next() {
               AcquisitionEvent channelEvent = event.copy();
               channelEvent.setChannelGroup(channelList.get(index).group_);
               channelEvent.setChannelConfig(channelList.get(index).config_);
               boolean hasZOffsets = channelList.stream().map(t -> t.offset_).
                       filter(t -> t != 0).collect(Collectors.toList()).size() > 0;
               Double zPos;
               if (channelEvent.getZPosition() == null) {
                  if (hasZOffsets) {
                     try {
                        zPos = Engine.getCore().getPosition() + channelList.get(index).offset_;
                     } catch (Exception e) {
                        throw new RuntimeException(e);
                     }
                  } else {
                     zPos = null;
                  }
               } else {
                  zPos = channelEvent.getZPosition() + channelList.get(index).offset_;
               }
               channelEvent.setZ(channelEvent.getZIndex(), zPos);

//               try {
//                  channelEvent.setZ(channelEvent.getZIndex(),
//                          channelEvent.getZPosition() == null ?
//                                  hasZOffsets ?
//                                          Engine.getCore().getPosition() + channelList.get(index).offset_ : null
//                                  : channelEvent.getZPosition() + channelList.get(index).offset_
//                  );
//               } catch (Exception e) {
//                  throw new RuntimeException(e);
//               }
               channelEvent.setExposure(channelList.get(index).exposure_);
               index++;
               return channelEvent;
            }
         };
      };
   }

   /**
    * Iterate over an arbitrary list of positions. Adds in postition indices to
    * the axes that assumer the order in the list provided correspond to the
    * desired indices
    *
    * @param positions
    * @return
    */
   public static Function> positions(List positions) {
      return (AcquisitionEvent event) -> {
         Stream.Builder builder = Stream.builder();
         if (positions == null) {
            builder.accept(event);
         } else {
            for (int index = 0; index < positions.size(); index++) {
               AcquisitionEvent posEvent = event.copy();
               posEvent.setX(positions.get(index).getCenter().x);
               posEvent.setY(positions.get(index).getCenter().y);
               posEvent.setGridRow(positions.get(index).getGridRow());
               posEvent.setGridCol(positions.get(index).getGridCol());
               posEvent.setAxisPosition(AcqEngMetadata.AXES_GRID_ROW, positions.get(index).getGridRow());
               posEvent.setAxisPosition(AcqEngMetadata.AXES_GRID_COL, positions.get(index).getGridCol());
//               posEvent.setAxisPosition(AcqEngMetadata.POSITION_AXIS, index);
               builder.accept(posEvent);
            }
         }
         return builder.build().iterator();
      };
   }

}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy