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

com.actelion.research.util.ScaleLabelCreator Maven / Gradle / Ivy

There is a newer version: 2024.12.1
Show newest version
/*
 * Copyright 2017 Idorsia Pharmaceuticals Ltd., Hegenheimermattweg 91, CH-4123 Allschwil, Switzerland
 *
 * This file is part of DataWarrior.
 * 
 * DataWarrior 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.
 * 
 * DataWarrior 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 DataWarrior.
 * If not, see http://www.gnu.org/licenses/.
 *
 * @author Thomas Sander
 */

package com.actelion.research.util;

import java.util.ArrayList;

public class ScaleLabelCreator {

	/**
	 * Creates a list of scale labels with their relative positions for a linear
	 * numerical scale with given numerical value range.
	 * @param rangeLow low limit of numerical range
	 * @param rangeHigh high limit of numerical range
	 * @return list of labels with relative positions
	 */
	public static ArrayList createLinearLabelList(double rangeLow, double rangeHigh) {
		if (rangeHigh <= rangeLow)
			return null;

		double range = rangeHigh - rangeLow;

		int exponent = 0;
		while (range >= 50.0) {
			rangeLow /= 10;
			range /= 10;
			exponent++;
			}
		while (range < 5.0) {
			rangeLow *= 10;
			range *= 10.0;
			exponent--;
			}

		int gridSpacing = (int)(range / 10);
	    if (gridSpacing < 1)
			gridSpacing = 1;
		else if (gridSpacing < 2)
			gridSpacing = 2;
		else
			gridSpacing = 5;

	    int value = (rangeLow < 0) ?
		      (int)(rangeLow - 0.0000001 - (rangeLow % gridSpacing))
			: (int)(rangeLow + 0.0000001 + gridSpacing - (rangeLow % gridSpacing));

		ArrayList labelList = new ArrayList();
		while (value < (rangeLow + range)) {
			double position = (value-rangeLow) / range;

			labelList.add(new ScaleLabel(DoubleFormat.toShortString(value, exponent), position, value*Math.pow(10, exponent)));

			value += gridSpacing;
			}

		return labelList;
		}

	/**
	 * Creates a list of scale labels with their relative positions for a
	 * logarithmical numerical scale with given numerical value range.
	 * @param rangeLow log10 of low limit of numerical range
	 * @param rangeHigh log10 of high limit of numerical range
	 * @return list of labels with relative positions
	 */
	public static ArrayList createLogarithmicLabelList(double rangeLow, double rangeHigh) {
		if (rangeHigh <= rangeLow)
			return null;

		double range = rangeHigh - rangeLow;

        int intMin = (int)Math.floor(rangeLow);
        int intMax = (int)Math.floor(rangeHigh);
        
		ArrayList labelList = new ArrayList();
        if (range > 5.4) {
            int step = 1 + (int)range/10;
            for (int i=intMin; i<=intMax; i+=step)
                addLogarithmicScaleLabel(labelList, i, rangeLow, range);
            }
        else if (range > 3.6) {
            for (int i=intMin; i<=intMax; i++) {
                addLogarithmicScaleLabel(labelList, i, rangeLow, range);
                addLogarithmicScaleLabel(labelList, i + 0.47712125472f, rangeLow, range);
                }
            }
        else if (range > 1.8) {
            for (int i=intMin; i<=intMax; i++) {
                addLogarithmicScaleLabel(labelList, i, rangeLow, range);
                addLogarithmicScaleLabel(labelList, i + 0.301029996f, rangeLow, range);
                addLogarithmicScaleLabel(labelList, i + 0.698970004f, rangeLow, range);
                }
            }
        else if (range > 1.0) {
            for (int i=intMin; i<=intMax; i++) {
                addLogarithmicScaleLabel(labelList, i, rangeLow, range);
                addLogarithmicScaleLabel(labelList, i + 0.176091259f, rangeLow, range);
                addLogarithmicScaleLabel(labelList, i + 0.301029996f, rangeLow, range);
                addLogarithmicScaleLabel(labelList, i + 0.477121255f, rangeLow, range);
                addLogarithmicScaleLabel(labelList, i + 0.698970004f, rangeLow, range);
                addLogarithmicScaleLabel(labelList, i + 0.84509804f, rangeLow, range);
                }
            }
		else if (range > 0.6) {
			for (int i=intMin; i<=intMax; i++) {
				addLogarithmicScaleLabel(labelList, i, rangeLow, range);						// 1.0
				addLogarithmicScaleLabel(labelList, i + 0.113943352f, rangeLow, range);	// 1.3
				addLogarithmicScaleLabel(labelList, i + 0.204119983f, rangeLow, range);	// 1.6
				addLogarithmicScaleLabel(labelList, i + 0.301029996f, rangeLow, range);	// 2.0
				addLogarithmicScaleLabel(labelList, i + 0.397940009f, rangeLow, range);	// 2.5
				addLogarithmicScaleLabel(labelList, i + 0.505149978f, rangeLow, range);	// 3.2
				addLogarithmicScaleLabel(labelList, i + 0.602059991f, rangeLow, range);	// 4.0
				addLogarithmicScaleLabel(labelList, i + 0.698970004f, rangeLow, range);	// 5.0
				addLogarithmicScaleLabel(labelList, i + 0.806179974f, rangeLow, range);	// 6.4
				addLogarithmicScaleLabel(labelList, i + 0.903089987f, rangeLow, range);	// 8.0
				}
			}
        else {
			double start = Math.pow(10, rangeLow);
			double length = Math.pow(10, rangeLow+range) - start;

            int exponent = 0;
            while (length >= 50.0) {
                start /= 10;
                length /= 10;
                exponent++;
                }
            while (length < 5.0) {
                start *= 10;
                length *= 10.0;
                exponent--;
                }

            int gridSpacing = (int)(length / 10);
            if (gridSpacing < 1)
                gridSpacing = 1;
            else if (gridSpacing < 2)
                gridSpacing = 2;
            else
                gridSpacing = 5;

            int value = (start < 0) ?
                  (int)(start - 0.0000001 - (start % gridSpacing))
                : (int)(start + 0.0000001 + gridSpacing - (start % gridSpacing));
            while (value < (start + length)) {
				double log = Math.log10(value) + exponent;
				double position = (log-rangeLow) / range;
                labelList.add(new ScaleLabel(DoubleFormat.toShortString(value, exponent), position, log));
                value += gridSpacing;
                }
            }

        return labelList;
		}

    private static void addLogarithmicScaleLabel(ArrayList labelList, double value, double rangeLow, double range) {
        if (value >= rangeLow && value <= rangeLow+range) {
			double position = (value-rangeLow) / range;
            labelList.add(new ScaleLabel(DoubleFormat.toString(Math.pow(10, value), 3, true), position, value));
            }
        }
	}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy