You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
 
 
 
 
 
 

240 lines
6.1 KiB

//==============================================================================
//
// Copyright (c) 2013-
// Authors:
// * Ernst Moritz Hahn <emhahn@cs.ox.ac.uk> (University of Oxford)
//
//------------------------------------------------------------------------------
//
// This file is part of PRISM.
//
// PRISM 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 2 of the License, or
// (at your option) any later version.
//
// PRISM 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 PRISM; if not, write to the Free Software Foundation,
// Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
//
//==============================================================================
// TODO allow null values in entries
package param;
import java.util.ArrayList;
import java.util.BitSet;
/**
* Class to assign a value to each state of a model.
* Used by {@code RegionValues}.
*
* @author Ernst Moritz Hahn <emhahn@cs.ox.ac.uk> (University of Oxford)
* @see RegionValues
*/
final class StateValues {
/** assigns values to each state of the model */
private ArrayList<StateValue> values;
/** initial state of the model */
int initState;
/**
* Constructs new set of state values.
* Each state is mapped to {@code null}.
*
* @param numStates number of states of model
* @param initState initial state of the model
*/
StateValues(int numStates, int initState)
{
values = new ArrayList<StateValue>(numStates);
for (int state = 0; state < numStates; state++) {
values.add(state, null);
}
this.initState = initState;
}
/**
* Constructs new set of state values.
* Each state is mapped to the given value.
*
* @param numStates number of states of the model
* @param initState initial state of the model
* @param value value to map all states to
*/
StateValues(int numStates, int initState, StateValue value) {
this(numStates, initState);
for (int state = 0; state < numStates; state++) {
values.set(state, value);
}
}
/**
* Constructs new set of state values.
* Each state is mapped to the given value.
*
* @param numStates number of states of the model
* @param initState initial state of the model
* @param value value to map all states to
*/
StateValues(int numStates, int initState, boolean value) {
this(numStates, initState, new StateBoolean(value));
}
@Override
public String toString() {
return values.get(initState).toString();
}
@Override
public boolean equals(Object obj) {
if (!(obj instanceof StateValues)) {
return false;
}
StateValues result = (StateValues) obj;
for (int i = 0; i < values.size(); i++) {
if (!values.get(i).equals(result.values.get(i))) {
return false;
}
}
return true;
}
@Override
public int hashCode() {
int hash = 0;
for (int i = 0; i < values.size(); i++) {
hash = values.get(i).hashCode() + (hash << 6) + (hash << 16) - hash;
}
return hash;
}
/**
* Get value of given state.
*
* @param state state to get value of
* @return value of given state
*/
StateValue getStateValue(int state)
{
return values.get(state);
}
/**
* Set value of given state.
*
* @param state state to set value of
* @param value value to set for state
*/
void setStateValue(int state, StateValue value)
{
values.set(state, value);
}
/**
* Set value of given state.
*
* @param state state to set value of
* @param value value to set for state
*/
void setStateValue(int state, boolean value)
{
values.set(state, new StateBoolean(value));
}
/**
* Get value of given state as rational function.
* If the value of the state is not a function, this will lead to an error.
*
* @param state state to get value of
* @return value of the state as a function
*/
Function getStateValueAsFunction(int state)
{
return (Function) values.get(state);
}
/**
* Get value of given state as boolean.
* If the value of the state is not a boolean, this will lead to an error.
*
* @param state state to get value of
* @return value of the state as a boolean
*/
boolean getStateValueAsBoolean(int state)
{
return ((StateBoolean) values.get(state)).getValue();
}
/**
* Get value of initial state as rational function.
* If the value of the initial state is not a function, this will lead to an error.
*
* @return value of the initial state as a function
*/
Function getInitStateValueAsFunction()
{
return (Function) values.get(initState);
}
/**
* Get value of initial state as boolean.
* If the value of the initial state is not a boolean, this will lead to an error.
*
* @return value of the initial state as a boolean
*/
boolean getInitStateValueAsBoolean()
{
return ((StateBoolean) values.get(initState)).getValue();
}
/**
* Returns number of states of the model.
*
* @return number of states of the model
*/
int getNumStates()
{
return values.size();
}
/**
* Converts this state value assignment to a bitset.
* For this to work, all states must be mapped to booleans.
*
* @return bitset representing this state value assignment
*/
BitSet toBitSet() {
BitSet result = new BitSet(values.size());
for (int state = 0; state < values.size(); state++) {
result.set(state, getStateValueAsBoolean(state));
}
return result;
}
/**
* Instantiates the value to which each state is mapped at the given point.
* For this to work, all states must be mapped to rational functions.
*
* @param point point to instantiate state values
* @return array of {@code BigRational}s mapping each state to evaluated value
*/
public BigRational[] instantiate(Point point) {
BigRational[] result = new BigRational[values.size()];
for (int state = 0; state < values.size(); state++) {
result[state] = this.getStateValueAsFunction(state).evaluate(point);
}
return result;
}
}