Class NativeVideoBackend
java.lang.Object
org.episteme.nativ.media.video.backends.NativeVideoBackend
- All Implemented Interfaces:
VideoAlgorithmProvider, VideoBackend, AlgorithmProvider, Backend, ComputeBackend, CPUBackend, NativeBackend
@AutoService({Backend.class,ComputeBackend.class,VideoBackend.class,CPUBackend.class,NativeBackend.class})
public class NativeVideoBackend
extends Object
implements VideoBackend, CPUBackend, NativeBackend
Native Video Backend using Project Panama (FFM API).
- Since:
- 1.2
- Author:
- Silvere Martin-Michiellot, Gemini AI (Google DeepMind)
-
Constructor Summary
Constructors -
Method Summary
Modifier and TypeMethodDescriptionCreates and returns the backend instance (or returns self if it is the backend).Creates an execution context for running operations.Returns the type of hardware accelerator used by this backend.Returns the friendly name of this backend instance.Returns a description of the backend.doublegetId()Returns the unique identifier for this backend (e.g., "javafx", "jmol", "cuda").Returns the name of the native library this backend depends on.doublegetTime()getType()Returns the backend type category (e.g., "plotting", "molecular", "tensor", "math").<T> TGrabs the current frame as an image.booleanChecks if this backend is currently available (libraries loaded, etc.).booleanisLoaded()Checks if the native library is loaded and available.voidLoads a video resource.voidpause()voidplay()voidshutdown()Called when the application is shutting down or the backend is being replaced.voidstop()Methods inherited from class Object
clone, equals, finalize, getClass, hashCode, notify, notifyAll, toString, wait, wait, waitMethods inherited from interface AlgorithmProvider
description, getMetadata, scoreMethods inherited from interface Backend
getAlgorithmProviders, getStatusMessage, isExplicitlyDisabledMethods inherited from interface CPUBackend
supportsComplexNumbers, supportsFloatingPoint, supportsParallelOpsMethods inherited from interface VideoAlgorithmProvider
detectMotion, detectTransitions, getAlgorithmTypeMethods inherited from interface VideoBackend
getName, getPriority
-
Constructor Details
-
NativeVideoBackend
public NativeVideoBackend()
-
-
Method Details
-
isLoaded
public boolean isLoaded()Description copied from interface:NativeBackendChecks if the native library is loaded and available.- Specified by:
isLoadedin interfaceNativeBackend- Returns:
- true if the native library has been successfully loaded
-
getNativeLibraryName
Description copied from interface:NativeBackendReturns the name of the native library this backend depends on.- Specified by:
getNativeLibraryNamein interfaceNativeBackend- Returns:
- library name (e.g., "openblas", "cuda", "fftw3")
-
getType
Description copied from interface:BackendReturns the backend type category (e.g., "plotting", "molecular", "tensor", "math").- Specified by:
getTypein interfaceBackend- Specified by:
getTypein interfaceComputeBackend- Specified by:
getTypein interfaceCPUBackend- Specified by:
getTypein interfaceVideoBackend
-
getId
Description copied from interface:BackendReturns the unique identifier for this backend (e.g., "javafx", "jmol", "cuda").- Specified by:
getIdin interfaceBackend- Specified by:
getIdin interfaceComputeBackend- Specified by:
getIdin interfaceVideoBackend
-
getBackendName
Description copied from interface:VideoBackendReturns the friendly name of this backend instance.- Specified by:
getBackendNamein interfaceVideoBackend
-
getDescription
Description copied from interface:BackendReturns a description of the backend.- Specified by:
getDescriptionin interfaceBackend- Specified by:
getDescriptionin interfaceComputeBackend- Specified by:
getDescriptionin interfaceVideoBackend
-
isAvailable
public boolean isAvailable()Description copied from interface:BackendChecks if this backend is currently available (libraries loaded, etc.).Default implementation checks
Backend.isExplicitlyDisabled()and returns false if it is.- Specified by:
isAvailablein interfaceAlgorithmProvider- Specified by:
isAvailablein interfaceBackend- Specified by:
isAvailablein interfaceVideoBackend
-
shutdown
public void shutdown()Description copied from interface:BackendCalled when the application is shutting down or the backend is being replaced. Use this to release hardware resources, close file handles, or stop background threads.- Specified by:
shutdownin interfaceAlgorithmProvider- Specified by:
shutdownin interfaceBackend- Specified by:
shutdownin interfaceVideoBackend
-
createBackend
Description copied from interface:BackendCreates and returns the backend instance (or returns self if it is the backend).- Specified by:
createBackendin interfaceBackend- Specified by:
createBackendin interfaceComputeBackend- Specified by:
createBackendin interfaceVideoBackend- Returns:
- The backend implementation object
-
load
Description copied from interface:VideoBackendLoads a video resource.- Specified by:
loadin interfaceVideoBackend- Parameters:
path- File path or URL- Throws:
Exception
-
play
public void play()- Specified by:
playin interfaceVideoBackend
-
pause
public void pause()- Specified by:
pausein interfaceVideoBackend
-
stop
public void stop()- Specified by:
stopin interfaceVideoBackend
-
getTime
public double getTime()- Specified by:
getTimein interfaceVideoBackend
-
getDuration
public double getDuration()- Specified by:
getDurationin interfaceVideoBackend
-
grabFrame
public <T> T grabFrame()Description copied from interface:VideoBackendGrabs the current frame as an image.- Specified by:
grabFramein interfaceVideoBackend- Type Parameters:
T- the image type- Returns:
- the current frame
-
getAcceleratorType
Description copied from interface:ComputeBackendReturns the type of hardware accelerator used by this backend.- Specified by:
getAcceleratorTypein interfaceComputeBackend- Specified by:
getAcceleratorTypein interfaceCPUBackend- Specified by:
getAcceleratorTypein interfaceVideoBackend- Returns:
- the accelerator type
-
createContext
Description copied from interface:ComputeBackendCreates an execution context for running operations.The context should be used within a try-with-resources block to ensure proper cleanup of resources.
- Specified by:
createContextin interfaceComputeBackend- Specified by:
createContextin interfaceVideoBackend- Returns:
- new execution context
-