Adding more state reduction analysis.
[jpf-core.git] / main.jpf
index c0441820813a09bf3f78e78711a783072f70decc..9ef7754c722ff9ce072b220b95113ca3bf105c30 100644 (file)
--- a/main.jpf
+++ b/main.jpf
@@ -1,7 +1,9 @@
 target = main
 
 # This is the listener that can detect variable write-after-write conflicts
-listener=gov.nasa.jpf.listener.VariableConflictTracker
+#listener=gov.nasa.jpf.listener.VariableConflictTracker
+listener=gov.nasa.jpf.listener.StateReducer
+#listener=gov.nasa.jpf.listener.VariableConflictTracker,gov.nasa.jpf.listener.StateReducer
 
 # Potentially conflicting variables
 # Alarms
@@ -13,11 +15,17 @@ variables=currentLock
 # Switches
 #variables=currentSwitch
 # Lights
-#variables=color,hue,saturation
+#variables=colorChanged,currentHue,currentSaturation,currentLevel,currentSwitch,colorTemperature
+# Speeches
+#variables=level,oneUser
 # Music players
-#variables=status,level,trackDescription,trackData,mute
+#variables=status,duration,level,trackDescription,trackData,mute
 # Relay switch
 #variables=currentSwitch
+# Valves
+#variables=valve,valveLatestValue
+# Cameras
+#variables=image,alarmState
                        
 # Potentially conflicting apps (we default to App1 and App2 for now)
 apps=App1,App2
@@ -25,4 +33,15 @@ apps=App1,App2
 # Tracking the location.mode variable conflict
 #track_location_var_conflict=true
 
+# Debug mode for StateReducer
+debug_state_transition=true
+activate_state_reduction=true
+
+# Timeout in minutes (default is 0 which means no timeout)
+timeout=30
+
+search.class = gov.nasa.jpf.search.heuristic.RandomHeuristic
+search.heuristic.beam_search=true
 #search.class = gov.nasa.jpf.search.heuristic.UserHeuristic
+#search.class = gov.nasa.jpf.search.heuristic.BFSHeuristic
+#search.class = gov.nasa.jpf.search.heuristic.DFSHeuristic