(1) JBCNonTerm (EQUIVALENT transformation)
Reached a loop using the following run:
0:
java.lang.String = serialPersistentFields, CASE_INSENSITIVE_ORDER
[a827872(lv_0_0)]
<NO_12.main||0: push 0|| - || ->
String.serialVersionUID: iconstLong_-6849794470754667710
String.serialPersistentFields: a827874
String.CASE_INSENSITIVE_ORDER: o413937
String$CaseInsensitiveComparator.serialVersionUID: iconstLong_8575799808933029326
RuntimeException.serialVersionUID: iconstLong_-7034897190745766939
Exception.serialVersionUID: iconstLong_-3387516993124229948
Throwable.serialVersionUID: iconstLong_-3042686055658047285
i1: [0,+inf){0,+inf}
a827872([java.lang.String...]): length i1
a827874([java.io.ObjectStreamField|]): length iconst_0
o413937!: String$CaseInsensitiveComparator()
Relations:
1:
java.lang.String = serialPersistentFields, CASE_INSENSITIVE_ORDER
[a827872(lv_0_0)]
<NO_12.main||1: store INT to #1|| - ||iconst_0>
String.serialVersionUID: iconstLong_-6849794470754667710
String.serialPersistentFields: a827874
String.CASE_INSENSITIVE_ORDER: o413937
String$CaseInsensitiveComparator.serialVersionUID: iconstLong_8575799808933029326
RuntimeException.serialVersionUID: iconstLong_-7034897190745766939
Exception.serialVersionUID: iconstLong_-3387516993124229948
Throwable.serialVersionUID: iconstLong_-3042686055658047285
i1: [0,+inf){0,+inf}
a827872([java.lang.String...]): length i1
a827874([java.io.ObjectStreamField|]): length iconst_0
o413937!: String$CaseInsensitiveComparator()
Relations:
2:
java.lang.String = serialPersistentFields, CASE_INSENSITIVE_ORDER
[a827872(lv_0_0)]
<NO_12.main||2: push 0||#1: iconst_0|| ->
String.serialVersionUID: iconstLong_-6849794470754667710
String.serialPersistentFields: a827874
String.CASE_INSENSITIVE_ORDER: o413937
String$CaseInsensitiveComparator.serialVersionUID: iconstLong_8575799808933029326
RuntimeException.serialVersionUID: iconstLong_-7034897190745766939
Exception.serialVersionUID: iconstLong_-3387516993124229948
Throwable.serialVersionUID: iconstLong_-3042686055658047285
i1: [0,+inf){0,+inf}
a827872([java.lang.String...]): length i1
a827874([java.io.ObjectStreamField|]): length iconst_0
o413937!: String$CaseInsensitiveComparator()
Relations:
3:
java.lang.String = serialPersistentFields, CASE_INSENSITIVE_ORDER
[a827872(lv_0_0)]
<NO_12.main||3: store INT to #2||#1: iconst_0||iconst_0>
String.serialVersionUID: iconstLong_-6849794470754667710
String.serialPersistentFields: a827874
String.CASE_INSENSITIVE_ORDER: o413937
String$CaseInsensitiveComparator.serialVersionUID: iconstLong_8575799808933029326
RuntimeException.serialVersionUID: iconstLong_-7034897190745766939
Exception.serialVersionUID: iconstLong_-3387516993124229948
Throwable.serialVersionUID: iconstLong_-3042686055658047285
i1: [0,+inf){0,+inf}
a827872([java.lang.String...]): length i1
a827874([java.io.ObjectStreamField|]): length iconst_0
o413937!: String$CaseInsensitiveComparator()
Relations:
4:
java.lang.String = serialPersistentFields, CASE_INSENSITIVE_ORDER
[a827872(lv_0_0)]
<NO_12.main||4: load INT #2||#1: iconst_0, #2: iconst_0|| ->
String.serialVersionUID: iconstLong_-6849794470754667710
String.serialPersistentFields: a827874
String.CASE_INSENSITIVE_ORDER: o413937
String$CaseInsensitiveComparator.serialVersionUID: iconstLong_8575799808933029326
RuntimeException.serialVersionUID: iconstLong_-7034897190745766939
Exception.serialVersionUID: iconstLong_-3387516993124229948
Throwable.serialVersionUID: iconstLong_-3042686055658047285
i1: [0,+inf){0,+inf}
a827872([java.lang.String...]): length i1
a827874([java.io.ObjectStreamField|]): length iconst_0
o413937!: String$CaseInsensitiveComparator()
Relations:
Start state of loop:
java.lang.String = serialPersistentFields, CASE_INSENSITIVE_ORDER
[a413934(lv_0_0)]
<NO_12.main||4: load INT #2||#1: i104, #2: i105|| ->
String.serialVersionUID: iconstLong_-6849794470754667710
String.serialPersistentFields: a413933
String.CASE_INSENSITIVE_ORDER: o206967
String$CaseInsensitiveComparator.serialVersionUID: iconstLong_8575799808933029326
RuntimeException.serialVersionUID: iconstLong_-7034897190745766939
Exception.serialVersionUID: iconstLong_-3387516993124229948
Throwable.serialVersionUID: iconstLong_-3042686055658047285
a413933([java.io.ObjectStreamField|]): length iconst_0
o206967!: String$CaseInsensitiveComparator()
i1: [0,+inf){0,+inf}
a413934([java.lang.String...]): length i1
i104: [0,+inf)(4){0,+inf}
i105: [0,+inf)(7){0,+inf}
Relations:
In the loop head node, references [i105, i104] were interesting.
By SMT, we could prove
((0 <= initial_i104 and 0 <= initial_i105 and 0 <= initial_i1) and ((((path1_i138 = (path1_i104 - path1_i105) and path1_i138 = path1_i142 and path1_i144 = (path1_i105 + 1) and path1_i104 = res_i104 and path1_i144 = res_i105 and path1_i1 = res_i1 and path1_i104 = initial_i104 and path1_i105 = initial_i105 and path1_i1 = initial_i1) and (path1_i105 <= path1_i104 and T and path1_i142 >= 1)) or ((path2_i138 = (path2_i104 - path2_i105) and path2_i138 = path2_i141 and path2_i143 = (path2_i104 + 2) and path2_i145 = (path2_i105 + 1) and path2_i143 = res_i104 and path2_i145 = res_i105 and path2_i1 = res_i1 and path2_i104 = initial_i104 and path2_i105 = initial_i105 and path2_i1 = initial_i1) and (path2_i105 <= path2_i104 and T and path2_i141 < 1))) and (((res_i138 = (res_i104 - res_i105) and res_i138 = res_i142 and res_i144 = (res_i105 + 1)) and !(res_i105 <= res_i104 and T and res_i142 >= 1)) and ((res_i138 = (res_i104 - res_i105) and res_i138 = res_i141 and res_i143 = (res_i104 + 2) and res_i145 = (res_i105 + 1)) and !(res_i105 <= res_i104 and T and res_i141 < 1)))))
to be UNSAT. Consequently, the loop will not terminate.