/*
 * #%L
 * IsisFish data
 * %%
 * Copyright (C) 2006 - 2014 Ifremer, CodeLutin
 * %%
 * This program 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 (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, see
 * <http://www.gnu.org/licenses/gpl-3.0.html>.
 * #L%
 */
package exports;

import fr.ifremer.isisfish.datastore.SimulationStorage;
import fr.ifremer.isisfish.entities.Metier;
import fr.ifremer.isisfish.entities.Strategy;
import fr.ifremer.isisfish.entities.Population;
import fr.ifremer.isisfish.entities.PopulationGroup;
import fr.ifremer.isisfish.entities.Zone;
import fr.ifremer.isisfish.export.Export;
import fr.ifremer.isisfish.types.TimeStep;
import org.apache.commons.logging.Log;
import org.apache.commons.logging.LogFactory;
import org.nuiton.math.matrix.MatrixIterator;
import org.nuiton.math.matrix.MatrixND;
import scripts.ResultName;
import resultinfos.MatrixCatchPerStrategyMetPerZoneMet;

import java.io.Writer;

/**
 * Captures_AgeStructure.java
 * 
 * Export des captures en poids de la forme :
 * Population ; MÃƒÆ’Ã†â€™Ãƒâ€šÃ‚Â©tier ; Groupe ; Zone ; Pas de temps ; Valeur
 * 
 * @author anonymous <anonymous@labs.libre-entreprise.org>
 * @version $Revision: 1.4 $
 * 
 * Last update: $Date: 2007-05-24 09:30:07 $ by : $Author: bpoussin $
 */
public class Captures_AgeStructure implements Export {

    /** to use log facility, just put in your code: log.info("..."); */
    static private Log log = LogFactory.getLog(Captures_AgeStructure.class);

    protected String[] necessaryResult = {
        ResultName.MATRIX_CATCH_PER_STRATEGY_MET_PER_ZONE_MET
    };

    @Override
    public String[] getNecessaryResult() {
        return this.necessaryResult;
    }

    @Override
    public String getExportFilename() {
        return "Captures_AgeStructure";
    }

    @Override
    public String getExtensionFilename() {
        return ".csv";
    }

    @Override
    public String getDescription() {
        return "Export les captures annuelle par group et metier. tableau year;pop;metier;id;zonemet;nombre";
    }

    @Override
    public void export(SimulationStorage simulation, Writer out)
            throws Exception {
		out.write("year;population;metier;group;zone;value\n");

        for (Population pop : simulation.getParameter().getPopulations()) {
                MatrixND mat = simulation.getResultStorage().getMatrix(pop, 
					MatrixCatchPerStrategyMetPerZoneMet.NAME);
					mat = mat.sumOverDim(0,12);
					mat = mat.sumOverDim(1); // str
					mat = mat.reduceDims(1);
						
				for (MatrixIterator i = mat.iterator(); i.hasNext();) {
                    i.next();
                    Object[] sems = i.getSemanticsCoordinates();
					int year = (int) sems[0];
                    Metier metier = (Metier) sems[1];
                    PopulationGroup group = (PopulationGroup) sems[2];
                    Zone zone = (Zone) sems[3];
    
                    double val = i.getValue();
                    out.write(year + ";" + pop.getName() + ";" +metier.getName() + ";"
                            + group.getId() + ";" + zone.getName() + ";" + val + "\n");
                }

                 
                
        }
        
    }
}
