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

com.feedzai.fos.server.remote.api.IRemoteManager Maven / Gradle / Ivy

/*
 * $#
 * FOS API
 *  
 * Copyright (C) 2013 Feedzai SA
 *  
 * This software is licensed under the Apache License, Version 2.0 (the "Apache License") or the GNU
 * Lesser General Public License version 3 (the "GPL License"). You may choose either license to govern
 * your use of this software only upon the condition that you accept all of the terms of either the Apache
 * License or the LGPL License.
 * 
 * You may obtain a copy of the Apache License and the LGPL License at:
 * 
 * http://www.apache.org/licenses/LICENSE-2.0.txt
 * http://www.gnu.org/licenses/lgpl-3.0.txt
 * 
 * Unless required by applicable law or agreed to in writing, software distributed under the Apache License
 * or the LGPL License is distributed on an "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND,
 * either express or implied. See the Apache License and the LGPL License for the specific language governing
 * permissions and limitations under the Apache License and the LGPL License.
 * #$
 */
package com.feedzai.fos.server.remote.api;

import com.feedzai.fos.api.FOSException;
import com.feedzai.fos.api.Manager;
import com.feedzai.fos.api.ModelConfig;
import com.feedzai.fos.common.validation.NotBlank;
import com.feedzai.fos.common.validation.NotNull;

import java.rmi.Remote;
import java.rmi.RemoteException;
import java.util.List;
import java.util.Map;
import java.util.UUID;

/**
 * New interface for @{Manager} that also extends Remote (required for sharing with RMI clients).
 *
 * @author Marco Jorge ([email protected])
 */
@RemoteInterface(of = Manager.class)
public interface IRemoteManager extends Remote {
    /**
     * Adds a new model with the given configuration and using the given serialized classifier.
     *
     * @param config the configuration of the model
     * @param model  the new serialized classifier
     * @return the id of the new model
     * @throws RemoteException when creating the classifier was not possible
     */
    UUID addModel(ModelConfig config,byte[] model) throws RemoteException, FOSException;

    /**
     * Adds a new model with the given configuration and using a local classifier source.
     *
     * @param config        the configuration of the model
     * @param localFileName the local filename (absolute path) of the serialized classifier
     * @return the id of the new model
     * @throws RemoteException when creating the classifier was not possible
     */
    UUID addModel(ModelConfig config, @NotBlank String localFileName) throws RemoteException, FOSException;

    /**
     * Removes the model identified by modelId from the list of active scorers (does not delete classifier file).
     *
     * @param modelId the id of the model to remove
     * @throws RemoteException when removing the model was not possible
     */
    void removeModel(UUID modelId) throws RemoteException, FOSException;

    /**
     * Reconfigures the model identified by modelId with the given configuration.
     *
     * @param modelId the id of the model to update
     * @param config  the new configuration of the model
     * @throws RemoteException when reconfiguring the model was not possible
     */
    void reconfigureModel(UUID modelId,ModelConfig config) throws RemoteException, FOSException;

    /**
     * Reconfigures the model identified by modelId with the given configuration.
     * 

* Reloads the model now using the classifier model (does not delete previous classifier file). * * @param modelId the id of the model to update * @param config the new configuration of the model * @param model the new serialized classifier * @throws RemoteException when reconfiguring the model was not possible */ void reconfigureModel(UUID modelId,ModelConfig config,byte[] model) throws RemoteException, FOSException; /** * Reconfigures the model identified by modelId with the given configuration. *

* Reloads the model now using the classifier in the local file localFileName (does not delete previous classifier file). * * @param modelId the id of the model to update * @param config the new configuration of the model * @param localFileName the local filename (absolute path) of the serialized classifier * @throws RemoteException when reconfiguring the model was not possible */ void reconfigureModel(UUID modelId,ModelConfig config, @NotBlank String localFileName) throws RemoteException, FOSException; /** * Lists the models configured in the system. * * @return a map of modelId to model configuration * @throws RemoteException when listing the maps was not possible */ @NotNull Map listModels() throws RemoteException, FOSException; /** * Gets a scorer loaded with all the active models. * * @return a scorer * @throws RemoteException when loading the scorer was not possible */ @NotNull RemoteScorer getScorer() throws RemoteException, FOSException; /** * Trains a new classifier with the given configuration and using the given instances. *

Automatically add the new model to the existing scorer. * * @param config the model configuration * @param instances the training instances * @return the id of the new model * @throws RemoteException when training was not possible */ UUID trainAndAdd(ModelConfig config,List instances) throws RemoteException, FOSException; /** * Trains a new classifier with the given configuration and using the instances. * in a CSV encoded file *

Automatically add the new model to the existing scorer. * * @param config the model configuration * @param path the training instances * @return the id of the new model * @throws FOSException when training was not possible */ UUID trainAndAddFile(ModelConfig config,String path) throws RemoteException,FOSException; /** * Trains a new classifier with the given configuration and using the given instances. * * @param config the model configuration * @param instances the training instances * @return a serialized representation of the model * @throws RemoteException when training was not possible */ @NotNull byte[] train(ModelConfig config,List instances) throws RemoteException, FOSException; /** * Trains a new classifier with the given configuration and using the given instances. * * @param config the model configuration * @param path File with the training instances * @return a serialized representation of the model * @throws FOSException when training was not possible */ @NotNull byte[] trainFile(ModelConfig config, String path) throws RemoteException, FOSException; /** * Frees any resources allocated to this manager. * * @throws RemoteException when closing resources was not possible */ void close() throws RemoteException, FOSException; /** * Saves a UUID identified classifier to a given savepath * @param uuid model uuid * @param savepath export model path */ void save(UUID uuid, String savepath) throws RemoteException, FOSException; }





© 2015 - 2025 Weber Informatics LLC | Privacy Policy