
 
package simulationplans;

import static org.nuiton.i18n.I18n._;

import org.apache.commons.logging.Log;
import org.apache.commons.logging.LogFactory;

import scripts.ResultName;

import java.io.Writer;
import org.nuiton.math.matrix.*;
import org.nuiton.util.*;
import org.nuiton.topia.*;

import fr.ifremer.isisfish.util.Doc;
import fr.ifremer.isisfish.*;
import fr.ifremer.isisfish.simulator.SimulationContext;
import fr.ifremer.isisfish.types.TimeStep;
import fr.ifremer.isisfish.entities.*;
import fr.ifremer.isisfish.simulator.SimulationPlan;
import fr.ifremer.isisfish.simulator.SimulationPlanContext;
import fr.ifremer.isisfish.simulator.SimulationParameter;
import fr.ifremer.isisfish.datastore.SimulationStorage;
import fr.ifremer.isisfish.datastore.ResultStorage;

/**
 * PlanSimuSelectivite.java
 *
 * Created: 27 juin 2011
 *
 * @author Camille <user.name@vcs.hostName>
 * @version $Revision: 1545 $
 * Last update: $Date: 28 aout 2012 $
 * by : $Author: Stephanie Mahevas $
 */
public class PlanSimuSelectivite implements SimulationPlan {

    /** to use log facility, just put in your code: log.info("..."); */
    private static Log log = LogFactory.getLog(PlanSimuSelectivite.class);
    
    static private final String MATRIXSELECTIVITE = "matrixSelectivite"; /// Le fichier est donc matrixSelectivite.txt
    static private final String SELECTIVITYMERLU = "selectivityMerlu";
    static private final String SELECTIVITYLANGOUSTINE = "selectivityLangoustine";
	
	int param_parameterNumber = 2;
	public int param_first = 0;
	public int param_simulationNumber = 5;  //nombre de courbes de selectivite a��������������������������������������������������������������������������������������������������������������������������������������������������������������������������������������������������������������������������� tester
     public String param_directory = ""; //repertoir ou sont ranges les fichiers matrixSelectivite.txt,selectivityMerlu.txt,selectivityLangoustine.txt
 
     public String [] necessaryResult = {
	    // put here all necessary result for this rule
	    // example: 
	    // ResultName.MATRIX_BIOMASS,
	    // ResultName.MATRIX_NET_VALUE_OF_LANDINGS_PER_STRATEGY_MET,
    };

    @Override
    public String[] getNecessaryResult() {
        return this.necessaryResult;
    }

    /**
     * Permet d'afficher a l'utilisateur une aide sur le plan.
     * @return L''aide ou la description du plan
     */
    @Override
    public String getDescription() throws Exception {
        // TODO change descrition
        return _("TODO SELECTIVITY description plan");
    }

    /**
     * Appele au demarrage de la simulation, cette methode permet d''initialiser
     * des valeurs
     * @param simulation La simulation pour lequel on utilise cette regle
     */
    @Override
    public void init(SimulationPlanContext context) throws Exception {
        File dir = new File(param_directory);
        
        MatrixND matrix = MatrixFactory.getInstance().create(new int[]{param_simulationNumber, param_parameterNumber});
        matrix.importCSV(new FileReader(new File(dir, MATRIXSELECTIVITE + ".txt")), new int[]{0,0});
        matrix.setSemantics(1, Arrays.asList(new String[]{SELECTIVITYMERLU, SELECTIVITYLANGOUSTINE}));       
		System.out.println(matrix);
    }

	
	
	
	/**
     * @param name le nom de l'element a recuperer
     * @param simulation le numero de la simulation
     * @return
     */
    private String getString(String name, int simulation) throws Exception {
        File dir = new File(param_directory);
        Properties prop = new Properties();
        prop.load(new BufferedReader(new FileReader(new File(dir, name + ".txt"))));
		int ligne = simulation + param_first;
        int mod = (int)matrix.getValue(ligne , name);
        String result = prop.getProperty(""+mod);
        return result;
    }
	
    /**
     * Call before each simulation.
     * 
     * @param context plan context
     * @param nextSimulation storage used for next simulation
     * @return true if we must do next simulation, false to stop plan
     * @throws Exception
     */


// partie ou on decide si on refait une simulation ou si on s'arrete. 
    public boolean beforeSimulation(SimulationPlanContext context, SimulationStorage nextSimulation) throws Exception {
   	     int simNum = nextSimulation.getParameter().getSimulationPlanNumber();
         if (simNum + param_first < param_simulationNumber) {
             String selectivityMerlu  = getString (SELECTIVITYMERLU, simNum);
			 String selectivityLangoustine  = getString (SELECTIVITYLANGOUSTINE, simNum);
			 
			 nextSimulation.getInformation().addInformation("Selectivity Merlu ("+context.getNumber()+")= " + selectivityMerlu);
			 nextSimulation.getInformation().addInformation("Selectivity Langoustine ("+context.getNumber()+")= " + selectivityLangoustine);
			 
			/// modif les parametres dans la base de donn�������������������������������������������������������������������������������������������������������������������������������������������������������������������������������������������������������������������es :
			TopiaContext tx = nextSimulation.getStorage().beginTransaction();
            /// On r�������������������������������������������������������������������������������������������������������������������������������������������������������������������������������������������������������������������cup�������������������������������������������������������������������������������������������������������������������������������������������������������������������������������������������������������������������re les objets ISIS a modifier dans la base de donn�������������������������������������������������������������������������������������������������������������������������������������������������������������������������������������������������������������������es
			PopulationDAO popDAO = IsisFishDAOHelper.getPopulationDAO(tx);                     			
			Population popMerlu = popDAO.findByName("merluccius");
			Population popLangoustine = popDAO.findByName("nephrops");
			GearDAO gearDAO = IsisFishDAOHelper.getGearDAO(tx);
				
			Gear gearChalutSimple = GearDAO.findByName("chalut simple");
			Gear gearChalutJumeau = GearDAO.findByName("Chalut jumeau");
			
			Selectivity selMerlu = gearChalutSimple.getPopulationSelectivity(popMerlu);
			Equation eqMerlu = selMerlu.getEquation();                
            eqMerlu.setContent(selectivityMerlu);
			Selectivity selLangoustine = gearChalutSimple.getPopulationSelectivity(popLangoustine);
			Equation eqLangoustine = selLangoustine.getEquation();                
            eqLangoustine.setContent(selectivityLangoustine);
						
			Selectivity selMerlu = gearChalutJumeau.getPopulationSelectivity(popMerlu);
			Equation eqMerlu = selMerlu.getEquation();                
            eqMerlu.setContent(selectivityMerlu);
			Selectivity selLangoustine = gearChalutJumeau.getPopulationSelectivity(popLangoustine);
			Equation eqLangoustine = selLangoustine.getEquation();                
            eqLangoustine.setContent(selectivityLangoustine);
			
			
			tx.commitTransaction();
            return true;
         } else {
            return false;
        }
	}
	
 

    /**
     * Call after each simulation.
     * 
     * @param context plan context
     * @param lastSimulation storage used for simulation
     * @return true if we must do next simulation, false to stop plan
     * @throws Exception
     */
    @Override
    public boolean afterSimulation(SimulationPlanContext context,
            SimulationStorage lastSimulation) throws Exception {
       return true;
    }
}