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

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

There is a newer version: 0.10.8
Show newest version
///*
// * To change this template, choose Tools | Templates
// * and open the template in the editor.
// */
//package oms3.dsl.cosu;
//
//import oms3.dsl.*;
//import java.io.File;
//import java.io.IOException;
//import java.util.ArrayList;
//import java.util.Date;
//import java.util.List;
//import java.util.Map;
//import ngmf.util.cosu.luca.ExecutionHandle;
//import ngmf.util.cosu.luca.ParameterData;
//import oms3.Conversions;
//import oms3.dsl.cosu.Luca.ModelExecution;
//import oms3.SimConst;
//
///**
// *
// * @author od
// */
//public class Step implements Buildable {
//
//    String name;
//    Params params = new Params();
////    Opt opt = new Opt();
//    // sce control parameter
//    int NumOfParams = 0; // number of individual params (e.g. for 1 parameter with 12 entries, it is 12)
//    int maxExec = 10000;
//    int initComplexes = 2;
//    int minComplexes = 1;
//    // computed sce parameter
//    int pointsPerComplex = -1;
//    int pointsPerSubcomplex = -1;
//    int evolutions = -1;
//    //
//    int shufflingLoops = 5;
//    double ofPercentage = 0.01;
//    //
//    int number;
//    List ofs = new ArrayList();
//
//    Step(int number) {
//        this.number = number;
//    }
//
//    public void setName(String name) {
//        this.name = name;
//    }
//   
//    public String getName() {
//        return name == null ? Integer.toString(number) : name;
//    }
//
//    public int getInitComplexes() {
//        return initComplexes;
//    }
//
//    public int getMaxExec() {
//        return maxExec;
//    }
//
//    public int getMinComplexes() {
//        return minComplexes;
//    }
//
//    public int getEvolutions() {
//        return evolutions > -1 ? evolutions : (NumOfParams * 2 + 1);
//    }
//
//    public int getPointsPerComplex() {        
//        return pointsPerComplex > -1 ? pointsPerComplex : (NumOfParams * 2 + 1);
//    }
//
//    public int getPointsPerSubcomplex() {
//        return pointsPerSubcomplex > -1 ? pointsPerComplex : (NumOfParams + 1);
//    }
//
//    public double getOfPercentage() {
//        return ofPercentage;
//    }
//
//    public int getShufflingLoops() {
//        return shufflingLoops;
//    }
//
//    @Override
//    public Buildable create(Object name, Object value) {
//        if (name.equals("max_exec")) {
//            maxExec = (Integer) value;
//            if (maxExec < 1) {
//                throw new IllegalArgumentException("max_exec: " + maxExec);
//            }
//        } else if (name.equals("init_complexes")) {
//            initComplexes = (Integer) value;
//            if (initComplexes < 1) {
//                throw new IllegalArgumentException("init_complexes: " + initComplexes);
//            }
//        } else if (name.equals("points_per_complex")) {
//            pointsPerComplex = (Integer) value;
//        } else if (name.equals("points_per_subcomplex")) {
//            pointsPerSubcomplex = (Integer) value;
//        } else if (name.equals("evolutions")) {
//            evolutions = (Integer) value;
//        } else if (name.equals("min_complexes")) {
//            minComplexes = (Integer) value;
//            if (minComplexes < 1) {
//                throw new IllegalArgumentException("minComplexes: " + minComplexes);
//            }
//        } else if (name.equals("shuffling_loops")) {
//            shufflingLoops = (Integer) value;
//            if (shufflingLoops < 1) {
//                throw new IllegalArgumentException("shufflingLoops: " + shufflingLoops);
//            }
//        } else if (name.equals("of_percentage")) {
//            ofPercentage = Conversions.convert(value, Double.class);
//            if (ofPercentage <= 0.0 || ofPercentage > 1.0) {
//                throw new IllegalArgumentException("of_percentage: " + ofPercentage);
//            }
//        } else if (name.equals("parameter")) {
//            return params;
//        } else if (name.equals("objfunc")) {
//            ObjFunc of = new ObjFunc();
//            ofs.add(of);
//            return of;
//        } else {
//            throw new IllegalArgumentException(name.toString());
//        }
//        return LEAF;
//    }
//
//    public Params params() {
//        return params;
//    }
//
//    public boolean needsToStopSCE() {
//        return false;
//    }
//
//    public void setStatus(String string) {
//    }
//
//    public static class Data {
//
//        int round;
//        double bestOFPoint;
//        double[] upperBound;
//        double[] lowerBound;
//        double[] paramValues;
//        //
//        ParameterData[] paramData;
//        ParameterData[] bestParamData;
//
//        public void createBestParamData() {
//            bestParamData = new ParameterData[paramData.length];
//            for (int i = 0; i < bestParamData.length; i++) {
//                bestParamData[i] = new ParameterData(paramData[i]);
//            }
//        }
//        
//        void init(ParameterData[] params) {
//          
//            ParameterData[] pd = new ParameterData[params.length];
//            for (int i = 0; i < params.length; i++) {
//                pd[i] = new ParameterData(params[i]);
//            }
//            setParameterData(pd);
//            
//            int numOfParams = 0;
//            for (int i = 0; i < paramData.length; i++) {
//                numOfParams += paramData[i].getCalibrationDataSize();
//            }
//            
//            // transfer values from paramData array to paramValue
//            paramValues = new double[numOfParams];
//            lowerBound = new double[numOfParams];
//            upperBound = new double[numOfParams];
//
//            int index = 0;
//            for (int i = 0; i < paramData.length; i++) {
//                double[] values = paramData[i].getCalibrationData();
//                for (int j = 0; j < values.length; j++) {
//                    paramValues[index] = values[j];
//                    lowerBound[index] = paramData[i].getLowerBound();
//                    upperBound[index] = paramData[i].getUpperBound();
//                    index++;
//                }
//            }
//            bestOFPoint = 0.0;
//            }
//
//        public void setObjFuncValueOfBestPoint(double d) {
//            bestOFPoint = d;
//        }
//
//        public double getObjFuncValueOfBestPoint() {
//            return bestOFPoint;
//        }
//
//        public void setParameterData(ParameterData[] paramData) {
//            this.paramData = paramData;
//        }
//
//        public void setParamValues(double[] paramValues) {
//            this.paramValues = paramValues;
//            int index = 0;
//            for (int i = 0; i < paramData.length; i++) {
//                double[] data = new double[paramData[i].getCalibrationDataSize()];
//                if (paramValues.length < data.length) {
//                    throw new RuntimeException("CalibrationDataSize = " + paramData[i].getCalibrationDataSize() + 
//                          ";  but paramValues.length = " + paramValues.length);
//                }
//                for (int j = 0; j < data.length; j++) {                   
//                    data[j] = paramValues[index];
//                    index++;
//                }
//                paramData[i].generateValues(data);
//            }
//        }
//
//        public void setBestParamData(double[] bestParamValues, double bestOFPoint) {
//            this.bestOFPoint = bestOFPoint;
//            setBestParamData(bestParamValues);
//        }
//
//        public void setBestParamData(double[] bestParamValues) {
//            int index = 0;
//            for (int i = 0; i < bestParamData.length; i++) {
//                double[] data = new double[bestParamData[i].getCalibrationDataSize()];
//                for (int j = 0; j < data.length; j++) {
//                    data[j] = bestParamValues[index];
//                    index++;
//                }
//                bestParamData[i].generateValues(data);
//            }
//        }
//
//        public double[] getBestParamDataArray() {
//            double[] bestParamValues = new double[paramValues.length];
//            int index = 0;
//            for (int i = 0; i < bestParamData.length; i++) {
//                double[] values = bestParamData[i].getCalibrationData();
//                for (int j = 0; j < values.length; j++) {
//                    bestParamValues[index] = values[j];
//                    index++;
//                }
//            }
//            return bestParamValues;
//        }
//
//        public double[] getUpperBound() {
//            return upperBound;
//        }
//
//        public double[] getLowerBound() {
//            return lowerBound;
//        }
//
//        public double[] getParamValues() {
//            return paramValues;
//        }
//
//        static public void copyParamValues(Data source, Data dest) {
//            double[] paramValueArray = new double[source.getParamValues().length];
//            for (int i = 0; i < paramValueArray.length; i++) {
//                paramValueArray[i] = source.getParamValues()[i];
//            }
//            dest.setParamValues(paramValueArray);
//            dest.setBestParamData(paramValueArray);
//        }
//    }
//    Data[] r;
//
//    public Data[] round() {
//        return r;
//    }
//    ////////////////// Runtime fields and methods
//    Date calibStart;
//    Date calibEnd;
//    File outFolder;
//
//    void post(int round, Data step) {
//        for (int i = round + 1; i < r.length; i++) {
//            Data.copyParamValues(step, r[i]);
//        }
//    }
//
//    void init(ModelExecution model, Date calibStart, Date calibEnd, int rounds) throws IOException {
//        this.calibStart = calibStart;
//        this.calibEnd = calibEnd;
//        this.outFolder = model.lastFolder;
//
//        r = new Data[rounds];
//        ParameterData[] p = create(params(), model.getParameter());
//        for (int i = 0; i < rounds; i++) {
//            r[i] = new Data();
//            r[i].round = i;
//            r[i].init(p);
////            copy(sourceStepData.get(i), this.stepData[i], executionHandle);
//            r[i].createBestParamData();
//            this.NumOfParams += r[i].getParamValues().length;
//        }
//    }
//
//    public static ParameterData[] create(Params params, Map modelparams) {
//        ParameterData[] paramData = new ParameterData[params.getCount()];
//        for (int i = 0; i < paramData.length; i++) {
//            Param p = params.getParam().get(i);
//            Calibration calib = p.getCalibration();
//            String pname = p.getName();
//            Object pval = modelparams.get(pname);
//            
//            if (pval == null) {
//                throw new RuntimeException("Paramter not found '" + pname + "'");
//            }
////            System.out.println(pval + " " + pval.getClass());
//            if (pval.toString().indexOf('{') == -1 && pval.toString().indexOf('}') == -1) {
//                pval = '{' + pval.toString() + '}';
//            }
//            double[] pv = Conversions.convert(pval, double[].class);
//            
//            boolean[] calibrate = calib.getCalibrateFlags(pv.length);
//    
//            double lower = p.getLower();
//            double upper = p.getUpper();
//            if (Double.isNaN(upper)) {
//                throw new IllegalArgumentException("'upper' not set:" + pname);
//            }
//            if (Double.isNaN(lower)) {
//                throw new IllegalArgumentException("'lower' not set:" + pname);
//            }
//            if (lower > upper) {
//                throw new IllegalArgumentException("'lower' > 'upper' :" + pname);
//            }
//            paramData[i] = new ParameterData(pname);
//            paramData[i].set(pv, lower, upper, calib.getStrategyAsInt(), calibrate);
//        }
//        return paramData;
//    }
//
//    public boolean maximizeObjectiveFunctionValue() {
//        return ObjFunc.isInc(ofs);
//    }
//
//    public double calculateObjectiveFunctionValue(ExecutionHandle executionHandle) {
//        return ObjFunc.calculateObjectiveFunctionValue(ofs, calibStart, calibEnd, outFolder);
//    }
//
////    public static void main(String[] args) {
////       ParameterData p = new ParameterData("ggg");
////       p.set(new double[] {2.3}, 0, 4, ParameterData.MEAN, new boolean[] {true});
////       System.out.println(p.getMean());
////       p.generateValues(4.0);
////       System.out.println(Arrays.toString(p.getDataValue()));
////       System.out.println(p.getMean());
////    }
//}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy