/*
* Copyright 2008-2013, ETH Zürich, Samuel Welten, Michael Kuhn, Tobias Langner,
* Sandro Affentranger, Lukas Bossard, Michael Grob, Rahul Jain,
* Dominic Langenegger, Sonia Mayor Alonso, Roger Odermatt, Tobias Schlueter,
* Yannick Stucki, Sebastian Wendland, Samuel Zehnder, Samuel Zihlmann,
* Samuel Zweifel
*
* This file is part of Jukefox.
*
* Jukefox is free software: you can redistribute it and/or modify it under the
* terms of the GNU General Public License as published by the Free Software
* Foundation, either version 3 of the License, or any later version. Jukefox 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
* Jukefox. If not, see <http://www.gnu.org/licenses/>.
*/
package ch.ethz.dcg.jukefox.playmode.smartshuffle.agents;
import java.util.List;
import ch.ethz.dcg.jukefox.model.collection.BaseAlbum;
import ch.ethz.dcg.jukefox.model.collection.BaseArtist;
import ch.ethz.dcg.jukefox.model.collection.BaseSong;
import ch.ethz.dcg.jukefox.playmode.smartshuffle.SongVote;
import ch.ethz.dcg.jukefox.playmode.smartshuffle.agents.AgentManager.AgentType;
/**
* An agent in a first stage returns songs which should be considered for playing next and rates given songs by its
* knowledge of how well it will be accepted by the user.
*/
public interface IAgent {
/**
* Returns the type of this agent.
*
* @return The agent type
*/
public AgentType getAgentType();
/**
* Unique identifier for this agent.
*
* @return The agent id
*/
public String getIdentifier();
/**
* Returns a list of songs which the user could find interresting to listen to in the moment.
*
* @param num
* The number of songs which should be returned
* @return The songs the we are voting for
*/
public List<BaseSong<BaseArtist, BaseAlbum>> suggestSongs(int num);
/**
* Returns the votes for the given songs. If we consider a song as very interresting to play at the moment the vote
* is set to 1 and it is set to -1 if we think it is not good at all.
*
* @param songs
* The songs which we should rate
* @return The rated songs
*/
public List<SongVote> vote(List<BaseSong<BaseArtist, BaseAlbum>> songs);
}