summaryrefslogtreecommitdiff
path: root/java/src/org/singinst/uf/model/HazardRateNodeMetadataContentsFactory.java
blob: 2cf1de479cd47217adfd7522d971610dd42be854 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
package org.singinst.uf.model;

import java.util.ArrayList;
import java.util.Collection;
import java.util.HashMap;
import java.util.List;
import java.util.Map;

import org.singinst.uf.math.MathUtil;
import org.singinst.uf.math.SimplePoint;
import org.singinst.uf.presenter.ScalarValuePointList;
import org.singinst.uf.presenter.LineBounds;

public class HazardRateNodeMetadataContentsFactory {

	private final List<ScalarSchema> scalarSchemata = new ArrayList<ScalarSchema>();
	private final ScalarRelation relation;
	private final Map<Double, YearExtremeNodeMetadataContentsFactory> extremeByYear = new HashMap<Double, YearExtremeNodeMetadataContentsFactory>();
	
	private final List<PercentileDraggableLine> pointLists = new ArrayList<PercentileDraggableLine>();
	
	private final List<ScalarValueHolder> conjectureList = new ArrayList<ScalarValueHolder>();
	
	private static final double MID_YEAR = MathUtil.average(ModelUtil.EARLIEST_YEAR, ModelUtil.LATEST_YEAR);

	public HazardRateNodeMetadataContentsFactory(Node node) {
		IncidentBounds incidentBounds = new IncidentBounds();
		LineBounds yearBounds = new LineBounds(ModelUtil.EARLIEST_YEAR, ModelUtil.LATEST_YEAR);
		final List<IncidentExtremeNodeMetadataContentsFactory> extremes = IncidentExtremeNodeMetadataContentsFactory.createList(node, incidentBounds, yearBounds);
		for (YearExtremeNodeMetadataContentsFactory extreme : extremes) {
			extremeByYear.put(extreme.getYear(), extreme);
			scalarSchemata.addAll(extreme.getScalars());
		}
		for (ScalarSchema scalarSchema : scalarSchemata) {
			conjectureList.add(scalarSchema.getScalarValueHolder());
		}
		
		for (NotablePercentile percentile : NotablePercentile.values()) {
			PercentileDraggableLine pointList = new IncidentLine(this, percentile);
			pointLists.add(pointList);
		}

		relation = new ScalarRelation(new Axis(yearBounds), new Axis(incidentBounds)) {

			@Override
			public List<? extends ScalarValuePointList> getPointLists() {
				for (PercentileDraggableLine incidentLine : pointLists) {
					List<SimplePoint> points = new ArrayList<SimplePoint>();
					for (YearExtremeNodeMetadataContentsFactory extreme : extremes) {
						points.add(new SimplePoint(extreme.getYear(), 
								extreme.getScalarSchema(incidentLine.getPercentile()).getScalarValueHolder().getValue()));
					}
					incidentLine.setHypothesisPoints(points);
				}
				return pointLists;
			}

			public List<? extends ConclusionReportGenerator> getConclusionGenerators() {
				List<ConclusionReportGenerator> retVal = new ArrayList<ConclusionReportGenerator>();
				for (YearExtremeNodeMetadataContentsFactory extreme : extremes) {
					retVal.add(extreme.getConclusionGenerator());
				}
				return retVal;
			}

			public List<ScalarValueHolder> getScalarValues() {
				return conjectureList ;
			}
		};
	}

	public Collection<? extends ScalarSchema> getScalars() {
		return scalarSchemata;
	}

	public ScalarRelation getRelation() {
		return relation;
	}

	public void dragTo(NotablePercentile percentile, SimplePoint point) {
		boolean selectLeft = point.x < MID_YEAR;
		double year = selectLeft ? ModelUtil.EARLIEST_YEAR : ModelUtil.LATEST_YEAR;
		double anchorYear = selectLeft ? ModelUtil.LATEST_YEAR : ModelUtil.EARLIEST_YEAR;
		YearExtremeNodeMetadataContentsFactory extreme = extremeByYear.get(year);
		if (extreme == null) {
			throw new NullPointerException("" + year);
		}
		YearExtremeNodeMetadataContentsFactory anchorExtreme = extremeByYear.get(anchorYear);
		if (anchorExtreme == null) {
			throw new NullPointerException("" + year);
		}
		SimplePoint anchorPoint = new SimplePoint(
				anchorYear, anchorExtreme.getScalarSchema(percentile).getScalarValueHolder().getValue());
		double newExtremeY = MathUtil.interpolate(
				anchorPoint, point, year);
		extreme.getScalarSchema(percentile).getScalarValueHolder().setValue(newExtremeY);
	}
}