當前位置: 首頁>>代碼示例>>Java>>正文


Java Distribution類代碼示例

本文整理匯總了Java中eu.riscoss.reasoner.Distribution的典型用法代碼示例。如果您正苦於以下問題:Java Distribution類的具體用法?Java Distribution怎麽用?Java Distribution使用的例子?那麽, 這裏精選的類代碼示例或許可以為您提供幫助。


Distribution類屬於eu.riscoss.reasoner包,在下文中一共展示了Distribution類的15個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Java代碼示例。

示例1: printDistribution

import eu.riscoss.reasoner.Distribution; //導入依賴的package包/類
public static String printDistribution(Distribution dist) {
	
	String printDist = "[ ";
	int size = dist.getValues().size();
	if(size == 0)
		return "[ ]";
	if(size == 1)
		return "[ " + dist.getValues().get(0) + " ]";
	Double[] dblArr = new Double[size];
	dist.getValues().toArray(dblArr);
	for (int i = 0; i < size; i++) {
		printDist += dblArr[i];
		if(i < (size - 1)) {
			printDist += ", ";
		}
	}
	printDist += " ]";
	return printDist;
}
 
開發者ID:RISCOSS,項目名稱:riscoss-analyser,代碼行數:20,代碼來源:KPAExample.java

示例2: getDoubleArrayFromDistribution

import eu.riscoss.reasoner.Distribution; //導入依賴的package包/類
/**
 * Converts the <code>Distribution</code> object to <code>double[]</code> array.
 * @param distribution
 * @param chunk (just for reference)
 * @return <code>double[]</code> array
 */
private double[] getDoubleArrayFromDistribution(Distribution distribution, Chunk chunk) {
	
	List<Double> values = distribution.getValues();
	double[] result = new double[values.size()];
	int i = 0; double sum = 0.0;
	for (Double d : values) {
		result[i++] = d.doubleValue();
		sum += d;
	}
	/* sum != 1.0 */
	// seems that we need to introduce less rigorous check here, because of the floating point imprecision
	// therefore, lower and upper limits are introduced. 3 decimal places should be sufficient...
	if(sum < DIST_SUM_LIMIT_LOW || sum > DIST_SUM_LIMIT_HI) {
		throw new ReasonerException(String.format(
				"Sum of distribution values [raw: " + sum + ", formatted: %f] is not equal to 1.0 for node: '%s'. "
				+ "Check performed within limits: %f - %f", sum, chunk.getId(), DIST_SUM_LIMIT_LOW, DIST_SUM_LIMIT_HI));
	}
	return result;
}
 
開發者ID:RISCOSS,項目名稱:riscoss-analyser,代碼行數:26,代碼來源:KPARiskAnalysisTool.java

示例3: invalidCountOfDistributionLevels

import eu.riscoss.reasoner.Distribution; //導入依賴的package包/類
@Test
public void invalidCountOfDistributionLevels() {
	
	engine = new KPARiskAnalysisTool();
	engine.loadModel(convertStreamToString(
			KPAUnitTesting.class.getResourceAsStream("resources/valid/Timeliness.xdsl")));
	for (Chunk c : engine.queryModel(ModelSlice.INPUT_DATA)) {
		if ("VAverage_bug_fix_time__days_".equals(c.getId())) {
			Field f = engine.getField(c, FieldType.INPUT_VALUE);
			System.out.println("Read default distribution: " + f.getValue());
			List<Double> values = new ArrayList<Double>();
			values.add(0.42);
			values.add(0.22);
			Distribution distribution = new Distribution();
			distribution.setValues(values);
			f.setValue(distribution);
			this.exception.expect(ReasonerException.class);
			engine.setField(c, FieldType.INPUT_VALUE, f);
			break;
		}
	}
}
 
開發者ID:RISCOSS,項目名稱:riscoss-analyser,代碼行數:23,代碼來源:KPAUnitTesting.java

示例4: distributionSumNotEqualTo1

import eu.riscoss.reasoner.Distribution; //導入依賴的package包/類
/**
 * Test checks whether the exception is thrown for distribution sum > 1.0.
 */
@Test
public void distributionSumNotEqualTo1() {
	
	engine.loadModel(convertStreamToString(KPAUnitTesting.class.getResourceAsStream("resources/valid/Timeliness.xdsl")));
	
	Chunk chunk = new Chunk("VHour__When_the_commit_was_made", "Timeliness");
	Distribution distribution = new Distribution();
	List<Double> values = new ArrayList<>(0);
	values.add(0.5);
	values.add(0.4);
	values.add(0.3);
	distribution.setValues(values);
	Field field = new Field(DataType.DISTRIBUTION, distribution);
	
	this.exception.expect(ReasonerException.class);
	
	this.engine.setField(chunk, FieldType.INPUT_VALUE, field);
}
 
開發者ID:RISCOSS,項目名稱:riscoss-analyser,代碼行數:22,代碼來源:KPAUnitTesting.java

示例5: field2RiskData

import eu.riscoss.reasoner.Distribution; //導入依賴的package包/類
RiskData field2RiskData( String id, String target, Field f ) {
	RiskData rd = null;
	switch( f.getDataType() ) {
	case EVIDENCE: {
		Evidence e = f.getValue();
		rd = new RiskData( id, target, date, RiskDataType.EVIDENCE, e.pack() );
	}
	break;
	case DISTRIBUTION: {
		Distribution d = f.getValue();
		rd = new RiskData( id, target, date, RiskDataType.DISTRIBUTION, d.pack() );
	}
	break;
	case INTEGER:
	case REAL: {
		rd = new RiskData( id, target, date, RiskDataType.NUMBER, "" + f.getValue().toString() );
	}
	break;
	case STRING:
		break;
	case NaN:
	default:
		break;
	}
	return rd;
}
 
開發者ID:RISCOSS,項目名稱:riscoss-corporate,代碼行數:27,代碼來源:RiskAnalysisProcess.java

示例6: HorizontalDistributionGauge

import eu.riscoss.reasoner.Distribution; //導入依賴的package包/類
public HorizontalDistributionGauge( Distribution d, int w, int h, Color[] colors ) {
	
	super( w, h, BufferedImage.TYPE_INT_ARGB );
	
	if( colors == null ) {
		colors = new Color[d.getValues().size()];
		for( int i = 0; i < d.getValues().size(); i++ ) {
			colors[i] =  mkColor( i, d.getValues().size() );
		}
	}
	
	assert( d.getValues().size() == colors.length );
	
	this.distribution = d;
	this.colors = colors;
	
	this.bars = mkBars( d, mleft, mtop, w -(mleft + mright), h -(mtop + mbottom) );
	
	Graphics2D g = (Graphics2D)getGraphics();
	g.setRenderingHint(RenderingHints.KEY_ANTIALIASING, RenderingHints.VALUE_ANTIALIAS_ON );
	g.setColor( Color.white );
	g.fillRect( 0, 0, w, h );
	paint( d, g, mleft, mtop, w -(mleft + mright), h -(mtop + mbottom) );
}
 
開發者ID:RISCOSS,項目名稱:riscoss-corporate,代碼行數:25,代碼來源:HorizontalDistributionGauge.java

示例7: mkBars

import eu.riscoss.reasoner.Distribution; //導入依賴的package包/類
private Rectangle2D[] mkBars( Distribution d, int x, int y, int w, int h ) {
	Rectangle2D[] rects = new Rectangle2D[d.getValues().size()];
	double step = ((double)h) / d.getValues().size();
	for( int i = 0; i < d.getValues().size(); i++ ) {
		
		double val = d.getValues().get( i );
		
		double xi = x; // + w - (val * w); // + (step * i);
		double yi = y + (step * i); //+ h - (val * h);
		double hi = step -2;
		double wi = (val * w);
		
		rects[i] = new Rectangle2D.Double( xi, yi, wi, hi );
	}
	return rects;
}
 
開發者ID:RISCOSS,項目名稱:riscoss-corporate,代碼行數:17,代碼來源:HorizontalDistributionGauge.java

示例8: DistributionGauge

import eu.riscoss.reasoner.Distribution; //導入依賴的package包/類
public DistributionGauge( Distribution d, int w, int h, Color[] colors ) {
	
	super( w, h, BufferedImage.TYPE_INT_ARGB );
	
	if( colors == null ) {
		colors = new Color[d.getValues().size()];
		for( int i = 0; i < d.getValues().size(); i++ ) {
			colors[i] =  mkColor( i, d.getValues().size() );
		}
	}
	
	assert( d.getValues().size() == colors.length );
	
	this.distribution = d;
	this.colors = colors;
	
	this.bars = mkBars( d, mleft, mtop, w -(mleft + mright), h -(mtop + mbottom) );
	
	Graphics2D g = (Graphics2D)getGraphics();
	g.setRenderingHint(RenderingHints.KEY_ANTIALIASING, RenderingHints.VALUE_ANTIALIAS_ON );
	g.setColor( Color.white );
	g.fillRect( 0, 0, w, h );
	paint( d, g, mleft, mtop, w -(mleft + mright), h -(mtop + mbottom) );
}
 
開發者ID:RISCOSS,項目名稱:riscoss-corporate,代碼行數:25,代碼來源:DistributionGauge.java

示例9: mkBars

import eu.riscoss.reasoner.Distribution; //導入依賴的package包/類
private Rectangle2D[] mkBars( Distribution d, int x, int y, int w, int h ) {
	Rectangle2D[] rects = new Rectangle2D[d.getValues().size()];
	double step = ((double)w) / d.getValues().size();
	for( int i = 0; i < d.getValues().size(); i++ ) {
		
		double val = d.getValues().get( i );
		
		double xi = x + (step * i);
		double yi = y + h - (val * h);
		double hi = (val * h);
		double wi = step -2;
		
		rects[i] = new Rectangle2D.Double( xi, yi, wi, hi );
	}
	return rects;
}
 
開發者ID:RISCOSS,項目名稱:riscoss-corporate,代碼行數:17,代碼來源:DistributionGauge.java

示例10: getDistributionFromDoubleArray

import eu.riscoss.reasoner.Distribution; //導入依賴的package包/類
public static Distribution getDistributionFromDoubleArray(double[] array) {
	
	List<Double> values = new ArrayList<>();
	for (int i = 0; i < array.length; i++) {
		values.add(array[i]);
	}
	Distribution result = new Distribution();
	result.setValues(values);
	return result;
}
 
開發者ID:RISCOSS,項目名稱:riscoss-analyser,代碼行數:11,代碼來源:KPAExample.java

示例11: getDistributionFromDoubleArray

import eu.riscoss.reasoner.Distribution; //導入依賴的package包/類
/**
 * Converts the <code>double[]</code> array to <code>Distribution</code> object.
 * @param array
 * @return <code>Distribution</code>
 */
private Distribution getDistributionFromDoubleArray(double[] array) {
	
	List<Double> values = new ArrayList<>();
	for (int i = 0; i < array.length; i++) {
		values.add(array[i]);
	}
	Distribution result = new Distribution();
	result.setValues(values);
	return result;
}
 
開發者ID:RISCOSS,項目名稱:riscoss-analyser,代碼行數:16,代碼來源:KPARiskAnalysisTool.java

示例12: confirmEvidenceIsSet

import eu.riscoss.reasoner.Distribution; //導入依賴的package包/類
@Test
public void confirmEvidenceIsSet() {
	
	boolean result = false;
	engine = new KPARiskAnalysisTool();
	engine.loadModel(convertStreamToString(
			KPAUnitTesting.class.getResourceAsStream("resources/valid/Timeliness.xdsl")));
	for (Chunk c : engine.queryModel(ModelSlice.INPUT_DATA)) {
		if ("VAverage_bug_fix_time__days_".equals(c.getId())) {
			Field f = engine.getField(c, FieldType.INPUT_VALUE);
			System.out.println("Read default distribution: " + f.getValue());
			List<Double> values = new ArrayList<Double>();
			values.add(0.42);
			values.add(0.22);
			values.add(0.16);
			values.add(0.11);
			values.add(0.09);
			Distribution distribution = new Distribution();
			distribution.setValues(values);
			f.setValue(distribution);
			engine.setField(c, FieldType.INPUT_VALUE, f);
			Field f2 = engine.getField(c, FieldType.INPUT_VALUE);
			System.out.println("Compared distributions before and after setting the evidence: " + 
					f.getValue() + " - " + f2.getValue() + "\n");
			result = compareDistributions((Distribution)f.getValue(), (Distribution)f2.getValue());
			break;
		}
	}
	Assert.assertTrue(result);
}
 
開發者ID:RISCOSS,項目名稱:riscoss-analyser,代碼行數:31,代碼來源:KPAUnitTesting.java

示例13: toJson

import eu.riscoss.reasoner.Distribution; //導入依賴的package包/類
private JsonElement toJson(Distribution d) {
	JsonArray a = new JsonArray();
	for( double val : d.getValues() ) {
		a.add( new JsonPrimitive( "" + val ) );
	}
	return a;
}
 
開發者ID:RISCOSS,項目名稱:riscoss-corporate,代碼行數:8,代碼來源:ModelManager.java

示例14: flatten

import eu.riscoss.reasoner.Distribution; //導入依賴的package包/類
void flatten( Distribution d, int fixedBar ) {
	List<Double> v = d.getValues();
	double diff = diff( d );
	for( int i = 0; i < v.size(); i++ ) {
		if( diff == 0 ) break;
		if( i == fixedBar ) continue;
		double n = v.get( i ) + diff;
		if( n < 0 ) n = 0;
		if( n > 1 ) n = 1;
		v.set( i, n );
		diff = diff( d );
	}
}
 
開發者ID:RISCOSS,項目名稱:riscoss-corporate,代碼行數:14,代碼來源:GaugeServlet.java

示例15: paint

import eu.riscoss.reasoner.Distribution; //導入依賴的package包/類
private void paint( Distribution d, Graphics2D g, int x, int y, int w, int h ) {
	
	g.setFont( g.getFont().deriveFont( (float)10 ) );
	for( int i = 0; i < bars.length; i++ ) {
		Rectangle2D r = bars[i];
		g.setColor( colors[i] );
		g.fill( r );
		g.setColor( Color.black );
		g.draw( r );
		g.drawString( (int)(distribution.getValues().get( i ) * 100) + "%", (float)r.getX() +2, (float)r.getMaxY() -3 );
	}
}
 
開發者ID:RISCOSS,項目名稱:riscoss-corporate,代碼行數:13,代碼來源:HorizontalDistributionGauge.java


注:本文中的eu.riscoss.reasoner.Distribution類示例由純淨天空整理自Github/MSDocs等開源代碼及文檔管理平台,相關代碼片段篩選自各路編程大神貢獻的開源項目,源碼版權歸原作者所有,傳播和使用請參考對應項目的License;未經允許,請勿轉載。