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

com.actelion.research.calc.ScaleClasses Maven / Gradle / Ivy

There is a newer version: 2024.11.2
Show newest version
package com.actelion.research.calc;

import java.text.DecimalFormat;
import java.text.NumberFormat;
import java.util.*;

/**
 * Modest v. Korff
 * Idorsia Pharmaceuticals Ltd.
 * 18.01.2022 Start implementation
 **/
public class ScaleClasses {

	public static final double TINY = 0.0000001;

	private List liLimit;

	private boolean validated;

	public ScaleClasses(){
		liLimit = new ArrayList();
		validated=false;
	}


	public void add(double inLow, double inHigh, double scLow, double scHigh){
		Limit lim = new Limit(inLow, inHigh, scLow, scHigh);
		add(lim);

	}
	public void add(Limit lim){
		liLimit.add(lim);
		validated=false;
	}

	public double scale(double v){
		double sc = Double.NaN;

		if(!validated){
			if(!validate()){
				throw new RuntimeException("Validation failed! Discontinuous limits definition!");
			}
		}

		for (Limit limit : liLimit) {
			if(limit.isInRange(v)){
				sc = limit.scale(v);
				break;
			}
		}

		return sc;
	}

	public float scale(float v){
		float sc = 0;

		for (Limit limit : liLimit) {
			if(limit.isInRange(v)){
				sc = (float)limit.scale(v);
				break;
			}
		}

		return sc;
	}

	public boolean validate(){

		Collections.sort(liLimit, new Comparator() {
			@Override
			public int compare(Limit o1, Limit o2) {
				int c=0;

				if(o1.mInLow>o2.mInLow){
					c=1;
				} else if(o1.mInLowTINY){
				valid=false;
				break;
			}
		}
		return valid;
	}

	public static void main(String [] args){
		int n = 20;

		NumberFormat nf = new DecimalFormat("0.000");

		ScaleClasses scw = new ScaleClasses();
		scw.add(0.0, 0.25, 0, 0.45);
		scw.add(0.25, 0.75, 0.45, 0.55);
		scw.add(0.75, 1.0, 0.55, 1.0);


		Random rnd = new Random();

		List li = new ArrayList();
		li.add(0.0);
		li.add(0.1);
		li.add(0.25);
		li.add(0.5);
		li.add(0.6);
		li.add(0.7);
		li.add(0.8);
		li.add(0.9);
		li.add(0.91);
		li.add(1.0);


		for (Double ddd : li) {

			double sc = scw.scale(ddd);
			System.out.println("val " + nf.format(ddd) + " scaled " + nf.format(sc));
		}


//		for (int i = 0; i < n; i++) {
//			double v = rnd.nextDouble();
//			double sc = scw.scale(v);
//			System.out.println("val " + nf.format(v) + " scaled " + nf.format(sc));
//		}





	}

	public static class Limit {

		private double mInHigh;
		private double mInLow;

		private double mScHigh;
		private double mScLow;

		private double mDeltaIn;
		private double mDeltaSc;
		private double mScale;


		public Limit(double inLow, double inHigh, double scLow, double scHigh){
			this.mInHigh = inHigh;
			this.mScHigh = scHigh;
			this.mInLow = inLow;
			this.mScLow = scLow;

			init();
		}

		private void init(){
			mDeltaIn = mInHigh-mInLow;
			mDeltaSc = mScHigh-mScLow;

			mScale = mDeltaSc / mDeltaIn ;
		}


		public double scale(double v){
			double sc = 0;

			double vn = v-mInLow;

			sc = vn * mScale + mScLow;

			return sc;
		}

		public boolean isInRange(double v){
			if(v>=mInLow && v <= mInHigh)
				return true;
			else return false;
		}

	}
}




© 2015 - 2024 Weber Informatics LLC | Privacy Policy