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

boofcv.abst.tracker.PointTracker Maven / Gradle / Ivy

/*
 * Copyright (c) 2011-2020, Peter Abeles. All Rights Reserved.
 *
 * This file is part of BoofCV (http://boofcv.org).
 *
 * Licensed under the Apache License, Version 2.0 (the "License");
 * you may not use this file except in compliance with the License.
 * You may obtain a copy of the License at
 *
 *   http://www.apache.org/licenses/LICENSE-2.0
 *
 * Unless required by applicable law or agreed to in writing, software
 * distributed under the License is distributed on an "AS IS" BASIS,
 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
 * See the License for the specific language governing permissions and
 * limitations under the License.
 */

package boofcv.abst.tracker;

import boofcv.struct.image.ImageBase;

import java.util.List;

/**
 * 

* Interface for tracking point features in image sequences with automatic feature selection for use in * Structure From Motion (SFM) application. Access is provided to the pixel location of each track. * Implementation specific track information is hidden from the user. *

* *

* Each track can have the following states, active, inactive, new, and dropped. An active track is one * which was recently updated in the latest image, while an inactive one was not. New tracks were * spawned in the most recent image. Dropped tracks are tracks which were automatically dropped * in the most recent update. *

* *

* TRACK MAINTENANCE: Implementations of this interface should not automatically drop tracks or perform other forms of * track maintenance unless the feature is hopelessly lost and can no longer be tracked. It is the responsibility * of the user to drop tracks which are inactive for an excessive amount of time. New tracks should never be spawned * unless specifically requested by the user. *

* *

* TRACK MEMORY: Implementations of this interface must recycle tracks. After a track has been dropped, either by * the user or automatically, the reference should be saved and the user provided cookie * left unmodified. When a new track is added the track information should be updated and the * cookie left unmodified again. The intended purpose of this requirement is to reduce the * burden of memory maintenance on the user and to encourage good memory management. *

* *

* NOTE: Tracks dropped by the user will not be included in the dropped list. *

* * @author Peter Abeles */ public interface PointTracker> { /** * Process input image and perform tracking. * * @param image Next image in the sequence */ void process(T image); /** * Discard memory of all current and past tracks. Growing buffered might not be reset to * their initial size by this method. */ void reset(); /** * Returns the ID of the most recently processed frame. Frames start at 0 and increment by one each time * process is called. After reset or before any frames have been processed -1 is returned. */ long getFrameID(); /** * Returns the total number of active tracks */ int getTotalActive(); /** * Returns total number of inactive tracks */ int getTotalInactive(); /** * Drops all feature to be dropped and will no longer be tracked. * *

NOTE: Tracks dropped using this function will not appear in the dropped list.

*/ void dropAllTracks(); /** * Returns the maximum total number of tracks that it can spawn in a single frame. This number is reduced * by the number of active tracks. So if the maximum number of tracks it can spawn is 200 and 50 tracks are * active then it will spawn at most 150 tracks. If there is no limit then a number ≤ 0 is returned. */ int getMaxSpawn(); /** * Manually forces a track to be dropped. New requests to all and active lists will not include the track after * it has been dropped using this function. * * If request is made to drop a track that is not being tracked (in the internal all list), then the request * is ignored. * *

NOTE: Tracks dropped using this function will not appear in the dropped list.

* * @param track The track which is to be dropped * @return true if the request to drop the track was done or if it was ignored because the track wasn't being * tracked */ boolean dropTrack(PointTrack track); /** * Used to drop multiple tracks using a rule. This can be more efficient than dropping them one at a time. * *

NOTE: Tracks dropped using this function will not appear in the dropped list.

* * @param dropper Rule for dropping the tracks */ void dropTracks( Dropper dropper ); /** * Returns a list of all features that are currently being tracked * * @param list Optional storage for the list of tracks. * If null a new list will be declared internally. * @return List of tracks. */ List getAllTracks(List list); /** * Returns a list of active tracks. An active track is defined as a track * which was found in the most recently processed image. * * @param list Optional storage for the list of tracks. * If null a new list will be declared internally. * @return List of tracks. */ List getActiveTracks(List list); /** * Returns a list of inactive tracks. A track is inactive if it is not * associated with any features in the current image. * * @param list Optional storage for the list of tracks. * If null a new list will be declared internally. * @return List of tracks. */ List getInactiveTracks(List list); /** * Returns a list of tracks dropped by the tracker during the most recent update. * Tracks dropped by user request are not included in this list. * * @param list Optional storage for the list of tracks. * If null a new list will be declared internally. * @return List of tracks. */ List getDroppedTracks(List list); /** * Returns a list of tracks that have been added since process was called. * * @param list Optional storage for the list of tracks. * If null a new list will be declared internally. * @return List of tracks. */ List getNewTracks(List list); /** * Automatically selects new features in the image to track. Returned tracks must * be unique and not duplicates of any existing tracks. This includes both active * and inactive tracks. * * NOTE: This function may or may not also modify the active and inactive lists. */ void spawnTracks(); /** * Provides a custom rule for dropping tracks */ interface Dropper { /** * Called to see if a track should be dropped. DO NOT MODIFY THE TRACK HERE. * * @param track The track which is being examined. * @return true means drop the track and false means keep it */ boolean shouldDropTrack( PointTrack track ); } }




© 2015 - 2025 Weber Informatics LLC | Privacy Policy