(1) JBCNonTerm (EQUIVALENT transformation)
Reached a loop using the following run:
0:
java.lang.String = serialPersistentFields, CASE_INSENSITIVE_ORDER
[a84(lv_0_0)]
<simple.trueDiv.Main.main||0: load ADDR args||args: a84|| ->
String.serialVersionUID: iconstLong_-6849794470754667710
String.serialPersistentFields: a86
String.CASE_INSENSITIVE_ORDER: o45
String$CaseInsensitiveComparator.serialVersionUID: iconstLong_8575799808933029326
RuntimeException.serialVersionUID: iconstLong_-7034897190745766939
Exception.serialVersionUID: iconstLong_-3387516993124229948
Throwable.serialVersionUID: iconstLong_-3042686055658047285
i135: [0,+inf)(3){0,+inf}
a84([java.lang.String...]): length i135
a86([java.io.ObjectStreamField|]): length iconst_0
o45!: String$CaseInsensitiveComparator()
Relations:
1:
java.lang.String = serialPersistentFields, CASE_INSENSITIVE_ORDER
[a84(lv_0_0)]
<simple.trueDiv.Main.main||1: arraylength|| - ||a84>
String.serialVersionUID: iconstLong_-6849794470754667710
String.serialPersistentFields: a86
String.CASE_INSENSITIVE_ORDER: o45
String$CaseInsensitiveComparator.serialVersionUID: iconstLong_8575799808933029326
RuntimeException.serialVersionUID: iconstLong_-7034897190745766939
Exception.serialVersionUID: iconstLong_-3387516993124229948
Throwable.serialVersionUID: iconstLong_-3042686055658047285
i135: [0,+inf)(3){0,+inf}
a84([java.lang.String...]): length i135
a86([java.io.ObjectStreamField|]): length iconst_0
o45!: String$CaseInsensitiveComparator()
Relations:
2:
java.lang.String = serialPersistentFields, CASE_INSENSITIVE_ORDER
[a84(lv_0_0)]
<simple.trueDiv.Main.main||2: simple.trueDiv.TrueDiv.loop(I)V|| - ||i135>
String.serialVersionUID: iconstLong_-6849794470754667710
String.serialPersistentFields: a86
String.CASE_INSENSITIVE_ORDER: o45
String$CaseInsensitiveComparator.serialVersionUID: iconstLong_8575799808933029326
RuntimeException.serialVersionUID: iconstLong_-7034897190745766939
Exception.serialVersionUID: iconstLong_-3387516993124229948
Throwable.serialVersionUID: iconstLong_-3042686055658047285
i135: [0,+inf)(3){0,+inf}
a84([java.lang.String...]): length i135
a86([java.io.ObjectStreamField|]): length iconst_0
o45!: String$CaseInsensitiveComparator()
Relations:
3:
<simple.trueDiv.TrueDiv.loop||0: load INT i||i: i135|| ->
java.lang.String = serialPersistentFields, CASE_INSENSITIVE_ORDER
[a84(lv_0_0)]
<simple.trueDiv.Main.main||2: simple.trueDiv.TrueDiv.loop|| - ||i135>
String.serialVersionUID: iconstLong_-6849794470754667710
String.serialPersistentFields: a86
String.CASE_INSENSITIVE_ORDER: o45
String$CaseInsensitiveComparator.serialVersionUID: iconstLong_8575799808933029326
RuntimeException.serialVersionUID: iconstLong_-7034897190745766939
Exception.serialVersionUID: iconstLong_-3387516993124229948
Throwable.serialVersionUID: iconstLong_-3042686055658047285
i135: [0,+inf)(3){0,+inf}
a84([java.lang.String...]): length i135
a86([java.io.ObjectStreamField|]): length iconst_0
o45!: String$CaseInsensitiveComparator()
Relations:
Start state of loop:
<simple.trueDiv.TrueDiv.loop||0: load INT i||i: i46|| ->
java.lang.String = serialPersistentFields, CASE_INSENSITIVE_ORDER
[a21(lv_0_0)]
<simple.trueDiv.Main.main||2: simple.trueDiv.TrueDiv.loop|| - ||i10>
String.serialVersionUID: iconstLong_-6849794470754667710
String.serialPersistentFields: a20
String.CASE_INSENSITIVE_ORDER: o12
String$CaseInsensitiveComparator.serialVersionUID: iconstLong_8575799808933029326
RuntimeException.serialVersionUID: iconstLong_-7034897190745766939
Exception.serialVersionUID: iconstLong_-3387516993124229948
Throwable.serialVersionUID: iconstLong_-3042686055658047285
a20([java.io.ObjectStreamField|]): length iconst_0
o12!: String$CaseInsensitiveComparator()
i46: #I{-inf,+inf}
i10: [0,+inf)(1){0,+inf}
a21([java.lang.String...]): length i10
Relations:
In the loop head node, references [i46] were interesting.
By SMT, we could prove
(0 <= initial_i10 and ((((path1_i46 = path1_i51 and path1_i54 = (path1_i51 + -1) and path1_i54 = res_i46 and path1_i10 = res_i10 and path1_i46 = initial_i46 and path1_i10 = initial_i10) and path1_i51 <= 0) or ((path2_i46 = path2_i52 and path2_i55 = (path2_i52 + 1) and path2_i55 = res_i46 and path2_i10 = res_i10 and path2_i46 = initial_i46 and path2_i10 = initial_i10) and path2_i52 > 0)) and (((res_i46 = res_i51 and res_i54 = (res_i51 + -1)) and !res_i51 <= 0) and ((res_i46 = res_i52 and res_i55 = (res_i52 + 1)) and !res_i52 > 0))))
to be UNSAT. Consequently, the loop will not terminate.