F2SF.java 1.02 KB
package is2.data;


final public class F2SF extends IFV {

	final private float[] parameters;
	

	
	public float score =0;
	
	public F2SF(float[] p) {
		parameters =p;
	}
	
	@Override
	final  public void add(int i) {
		if (i>0) score += parameters[i];
	}

	  
	final  public void add(int[] i) {
		for(int k=0;k<i.length;k++) {
			if (i[k]>0) score += parameters[i[k]];
		}
	}
	
	
	final  public void sub(float[] px,int i, Long2IntInterface li) {
		
		if (i>0) {
			score -= px[li.l2i(i)];
//			score -= px[i];
			//else score -=px[];
		}
	}

	
	@Override
	public void clear() {
		score =0;
	}


	/* (non-Javadoc)
	 * @see is2.IFV#getScore()
	 */
	@Override
	public double getScore() {
		return score;
	}

	public float getScoreF() {
		return score;
	}

	/* (non-Javadoc)
	 * @see is2.IFV#clone()
	 */
	@Override
	public IFV clone() {
		return new F2SF(this.parameters);
	}

	/**
	 * @param l2i
	 */
	public void addRel(int i, float f) {
		if (i>0) score += parameters[i]*f;
		
	}
	
	public int length() {
		return this.parameters.length;
	}
	
	
}