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

oms3.dsl.cosu.Luca Maven / Gradle / Ivy

There is a newer version: 0.8.1
Show newest version
package oms3.dsl.cosu;

import java.io.FileNotFoundException;
import oms3.dsl.*;
import java.io.File;
import java.io.IOException;
import java.io.PrintWriter;
import java.util.ArrayList;
import java.util.Date;
import java.util.List;
import java.util.Map;
import java.util.logging.Level;
import java.util.logging.Logger;
import ngmf.util.OutputStragegy;
import ngmf.util.cosu.luca.ExecutionHandle;
import ngmf.util.cosu.luca.ParameterData;
import ngmf.util.cosu.luca.SCE;
import oms3.ComponentAccess;
import oms3.ComponentException;
import oms3.Compound;
import oms3.Conversions;
import oms3.annotations.Execute;
import oms3.annotations.Finalize;
import oms3.annotations.Initialize;
import oms3.dsl.cosu.Step.Data;
import oms3.io.DataIO;
import ngmf.util.cosu.luca.ParameterData;

// initial parameter settings (reading)
// calibration date/time settings.
// 
public class Luca extends AbstractSimulation {

    List steps = new ArrayList();
    //
    Date calib_start;           // Calibration start date
    int rounds = 1;             // number of rounds

    @Override
    public Buildable create(Object name, Object value) {
        if (name.equals("step")) {
            Step step = new Step(steps.size() + 1);
            steps.add(step);
            return step;
        } else if (name.equals("rounds")) {
            rounds = (Integer) value;
            if (rounds < 1) {
                throw new ComponentException("Illegal 'rounds': " + rounds);
            }
        } else if (name.equals("calibration_start")) {
            calib_start = Conversions.convert(value, Date.class);
        } else {
            return super.create(name, value);
        }
        return LEAF;
    }

    @Override
    public Object run() throws Exception {
        if (getModel() == null) {
            throw new ComponentException("missing 'model'.");
        }
        if (calib_start == null) {
            throw new ComponentException("missing 'calibration_start'");
        }
        if (steps.isEmpty()) {
            throw new ComponentException("missing 'step' definition(s)");
        }

        ModelExecution exec = new ModelExecution();
        Object end = exec.getParameter().get("endTime");
        Date endTime = Conversions.convert(end, Date.class);
        if (calib_start.after(endTime)) {
            throw new ComponentException("illegal calibration_start: " + calib_start);
        }
        for (Step step : steps) {
            step.init(exec, calib_start, endTime, rounds);
        }

        for (int r = 0; r < rounds; r++) {
            for (int s = 0; s < steps.size(); s++) {
                Step step = steps.get(s);
                Data stepData = step.round()[r];
                System.out.println("\n\n>>>>>>>>>>>>>>  Round [" + (r + 1) + "]  Step [" + step.getName() + "] <<<<<<<<<<<<<<");
                SCE sce = new SCE(exec, step, stepData);
                sce.run();
                exec.writeParameterCopy(step, r);
                step.post(r, stepData);
                Runtime.getRuntime().gc();
            }
        }
        Compound.shutdown();
        return null;
    }

    class ModelExecution implements ExecutionHandle {

        File lastFolder;
        Map parameter;

        public ModelExecution() throws IOException {
            OutputStragegy st = getOutput().getOutputStrategy(getName());
            lastFolder = st.nextOutputFolder();
            if (log.isLoggable(Level.CONFIG)) {
                log.config("Simulation output folder: " + lastFolder);
            }
            lastFolder.mkdirs();

            parameter = getModel().getParameter();
            Logger.getLogger("oms3.model").setLevel(Level.WARNING);
        }

        Map getParameter() {
            return parameter;
        }

        @Override
        public void execute(Step.Data step) throws Exception {

            // Path
            String libPath = getModel().getLibpath();
            if (libPath != null) {
                System.setProperty("jna.library.path", libPath);
                if (log.isLoggable(Level.CONFIG)) {
                    log.config("Setting jna.library.path to " + libPath);
                }
            }

            Object comp = getModel().getComponent();

            writeParameterFile(step);
            log.config("Init ...");
            ComponentAccess.callAnnotated(comp, Initialize.class, true);

            // setting the input data;
            boolean success = ComponentAccess.setInputData(parameter, comp, log);
            if (!success) {
                throw new RuntimeException("There are Parameter problems. Simulation exits.");
            }

            boolean adjusted = ComponentAccess.adjustOutputPath(lastFolder, comp, log);

            for (Output e : getOut()) {
                e.setup(comp, lastFolder, getName());
            }
            // execute phases and be done.
            log.config("Exec ...");
            ComponentAccess.callAnnotated(comp, Execute.class, false);
            log.config("Finalize ...");
            ComponentAccess.callAnnotated(comp, Finalize.class, true);

            for (Output e : getOut()) {
                e.done();
            }
        }

        @Override
        public void writeParameterFile(Step.Data step) {
            ParameterData[] paramData = step.paramData;
            for (int i = 0; i < paramData.length; i++) {
                String name = paramData[i].getName();
                int calibType = paramData[i].getCalibrationType();
               // System.out.println("****** " + name + " is ctype " + calibType);
                double[] val = paramData[i].getDataValue();
                if (calibType == ParameterData.BINARY) {
                  int [] ival = new int[val.length];
                  
                    for (int j=0; j< val.length; j++) {
                        ival[j] = (int) val[j];
                    }
                    parameter.put(name, toValueI(name,ival));
                }
                else {      
                    parameter.put(name, toValue(name, val));
                }
            }
        }
        

        public void writeParameterCopy(Step step, int round) throws FileNotFoundException {
            File params = new File(lastFolder, "round-" + (round + 1) + "_step-" + step.getName() + ".csv");
            System.out.println(" Final parameter file: '" + params + "'");
            PrintWriter pw = new PrintWriter(params);
            DataIO.print(parameter, "Parameter", pw);
            pw.close();
        }

        private Object toValue(String name, double[] vals) {
            Object orig = parameter.get(name);
            if (orig.toString().indexOf('{') > -1) {
                // this is an array (hopefully 1dim)
                return Conversions.convert(vals, String.class);
            } else {
                return Double.toString(vals[0]);
            }
        }
        
        private Object toValueI(String name, int[] vals) {
            Object orig = parameter.get(name);
            if (orig.toString().indexOf('{') > -1) {
                // this is an array (hopefully 1dim)
                return Conversions.convert(vals, String.class);
            } else {
                return Integer.toString(vals[0]);
            }
        }
        
    }
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy