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

org.nd4j.linalg.api.memory.MemoryWorkspaceManager Maven / Gradle / Ivy

There is a newer version: 1.0.0-M2.1
Show newest version
/*
 *  ******************************************************************************
 *  *
 *  *
 *  * This program and the accompanying materials are made available under the
 *  * terms of the Apache License, Version 2.0 which is available at
 *  * https://www.apache.org/licenses/LICENSE-2.0.
 *  *
 *  *  See the NOTICE file distributed with this work for additional
 *  *  information regarding copyright ownership.
 *  * 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.
 *  *
 *  * SPDX-License-Identifier: Apache-2.0
 *  *****************************************************************************
 */

package org.nd4j.linalg.api.memory;

import org.nd4j.linalg.api.memory.conf.WorkspaceConfiguration;

import org.nd4j.linalg.api.memory.enums.DebugMode;

import java.util.List;


public interface MemoryWorkspaceManager {

    /**
     * Returns globally unique ID
     *
     * @return
     */
    String getUUID();

    /**
     * This method returns current debug mode active in this JVM
     * @return
     */
    DebugMode getDebugMode();

    /**
     * This method allows to enable (and pick one) global debug mode for workspaces
     * Default value: DISABLED
     * @param mode
     */
    void setDebugMode(DebugMode mode);

    /**
     * This method sets default workspace configuration for this provider instance
     *
     * @param configuration
     */
    void setDefaultWorkspaceConfiguration(WorkspaceConfiguration configuration);

    /**
     * This method builds new Workspace with given configuration
     *
     * @param configuration
     * @return
     */
    MemoryWorkspace createNewWorkspace(WorkspaceConfiguration configuration);

    /**
     * This method builds new Workspace with default configuration
     *
     * @return
     */
    MemoryWorkspace createNewWorkspace();

    /**
     * This method builds new Workspace with given configuration
     *
     * @param configuration
     * @return
     */
    MemoryWorkspace createNewWorkspace(WorkspaceConfiguration configuration, String id);


    /**
     * This method builds new Workspace with given configuration
     *
     * @param configuration
     * @return
     */
    MemoryWorkspace createNewWorkspace(WorkspaceConfiguration configuration, String id, Integer deviceId);

    /**
     * This method returns you current default Workspace for current Thread
     *
     * PLEASE NOTE: If Workspace wasn't defined, new Workspace will be created using current default configuration
     *
     * @return
     */
    MemoryWorkspace getWorkspaceForCurrentThread();

    /**
     * This method returns you Workspace for a given Id for current Thread
     *
     * PLEASE NOTE: If Workspace wasn't defined, new Workspace will be created using current default configuration
     *
     * @return
     */
    MemoryWorkspace getWorkspaceForCurrentThread(String id);

    /**
     * This method returns you Workspace for a given Id for current Thread
     *
     * PLEASE NOTE: If Workspace wasn't defined, new Workspace will be created using given configuration
     *
     * @return
     */
    MemoryWorkspace getWorkspaceForCurrentThread(WorkspaceConfiguration configuration, String id);

    /**
     * This method allows you to set given Workspace as default for current Thread
     *
     * @param workspace
     */
    void setWorkspaceForCurrentThread(MemoryWorkspace workspace);

    /**
     * This method allows you to set given Workspace for spacific Id for current Thread
     *
     * @param workspace
     */
    void setWorkspaceForCurrentThread(MemoryWorkspace workspace, String id);

    /**
     * This method allows you to destroy given Workspace
     *
     * @param workspace
     */
    void destroyWorkspace(MemoryWorkspace workspace);

    /**
     * This method destroys & deallocates all Workspaces for a calling Thread
     *
     * PLEASE NOTE: This method is NOT safe
     */
    void destroyAllWorkspacesForCurrentThread();

    /**
     * This method destroys current Workspace for current Thread
     */
    void destroyWorkspace();

    /**
     * This method gets & activates default workspace
     *
     * @return
     */
    MemoryWorkspace getAndActivateWorkspace();

    /**
     * This method gets & activates workspace with a given Id
     *
     * @return
     */
    MemoryWorkspace getAndActivateWorkspace(String id);

    /**
     * This method gets & activates default with a given configuration and Id
     *
     * @return
     */
    MemoryWorkspace getAndActivateWorkspace(WorkspaceConfiguration configuration, String id);

    /**
     * This method checks, if Workspace with a given Id was created before this call
     *
     * @param id
     * @return
     */
    boolean checkIfWorkspaceExists(String id);

    /**
     * This method checks, if Workspace with a given Id was created before this call, AND is active at the moment of call
     *
     * @param id
     * @return
     */
    boolean checkIfWorkspaceExistsAndActive(String id);

    /**
     * This method temporary opens block out of any workspace scope.
     *
     * PLEASE NOTE: Do not forget to close this block.
     *
     * @return
     */
    MemoryWorkspace scopeOutOfWorkspaces();

    /**
     * This method prints out allocation statistics for current thread
     */
    void printAllocationStatisticsForCurrentThread();

    /**
     * This method returns list of workspace IDs for current thread
     *
     * @return
     */
    List getAllWorkspacesIdsForCurrentThread();

    /**
     * This method returns all workspaces for current thread
     */
    List getAllWorkspacesForCurrentThread();

    /**
     * Determine if there are any workspaces open for the current thread.
     *
     * @return True if any workspaces are open for this thread, false otherwise
     */
    boolean anyWorkspaceActiveForCurrentThread();
}




© 2015 - 2024 Weber Informatics LLC | Privacy Policy