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

org.lenskit.gradle.Simulate.groovy Maven / Gradle / Ivy

/*
 * LensKit, an open source recommender systems toolkit.
 * Copyright 2010-2016 LensKit Contributors.  See CONTRIBUTORS.md.
 * Work on LensKit has been funded by the National Science Foundation under
 * grants IIS 05-34939, 08-08692, 08-12148, and 10-17697.
 *
 * This program is free software; you can redistribute it and/or modify
 * it under the terms of the GNU Lesser General Public License as
 * published by the Free Software Foundation; either version 2.1 of the
 * License, or (at your option) any later version.
 *
 * This program is distributed in the hope that it will be useful, but WITHOUT
 * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS
 * FOR A PARTICULAR PURPOSE. See the GNU General Public License for more
 * details.
 *
 * You should have received a copy of the GNU General Public License along with
 * this program; if not, write to the Free Software Foundation, Inc., 51
 * Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
 */
package org.lenskit.gradle

import org.gradle.api.tasks.InputFile
import org.gradle.api.tasks.OutputFiles

class Simulate extends LenskitTask {
    def File specFile

    Simulate() {
        conventionMapping.specFile = {
            project.file("$project.buildDir/${name}.json")
        }
        spec.outputFile = project.file("$project.buildDir/${name}-output.csv").toPath()
        // FIXME re-enable simulate task
        throw new UnsupportedOperationException("simulate task does not work")
    }

    /**
     * Specify the input file.
     * @param obj The name of the input file.
     */
    public void input(obj) {
        spec.inputFile = project.file(obj).toPath()
    }

    /**
     * Get the input file for the simulation.
     * @return The simulation input file.
     */
    @InputFile
    public File getInputFile() {
        return spec.inputFile?.toFile()
    }

    /**
     * Set the output file.
     * @param obj The output file.
     */
    public void output(obj) {
        spec.outputFile = project.file(obj).toPath()
    }

    /**
     * Get the primary output file for the simulation.
     * @return The CSV output file for the simulation.
     */
    public File getOutputFile() {
        return spec.outputFile?.toFile()
    }

    /**
     * Set the extended output file.
     * @param obj The extended output file.
     */
    public void extendedOutput(obj) {
        spec.extendedOutputFile = project.file(obj).toPath()
    }

    /**
     * Get the output file for the extended JSON output.
     * @return The file where the extended JSON output will be stored.
     */
    public File getExtendedOutputFile() {
        return spec.extendedOutputFile?.toFile()
    }

    public void algorithm(fn) {
         algorithm(null, fn)
    }

    public void algorithm(name, fn) {
        def file = project.file(fn)
        if (name == null) {
            name = file.name
        }
        // FIXME fix this
    }

    @OutputFiles
    public Set getOutputFiles() {
        return spec.outputFiles*.toFile()
    }

    public void listSize(int s) {
        spec.listSize = s
    }

    public int setListSize(int s) {
        spec.listSize = s
    }

    public int getListSize() {
        return spec.listSize
    }

    public void rebuildPeriod(long p) {
        spec.rebuildPeriod = p
    }

    public void setRebuildPeriod(long p) {
        spec.rebuildPeriod = p
    }

    public long getRebuildPeriod() {
        return spec.rebuildPeriod
    }

    @Override
    protected void doPrepare() {
        def file = getSpecFile()
        project.mkdir file.parentFile
        logger.info('preparing spec file {}', file)
    }

    @Override
    String getCommand() {
        return "simulate"
    }

    @Override
    List getCommandArgs() {
        return ["--spec-file", getSpecFile()]
    }
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy