Переменные $foo_rel
и $foo_s
введены из-за сколемизации, так как вы выполняете количественную оценку по кортежу arity 2. (Лично я до сих пор игнорировал детали сколемизации и ненавижу ее только тогда, когда она не работает.)
Однако я не думаю, что это ваша проблема. Я запустил модель без целых чисел:
check foo for 2 but 0 int
Это дало следующее решение:
---INSTANCE---
integers={}
univ={B$0, Foo$0}
Int={}
seq/Int={}
String={}
none={}
this/Foo={Foo$0}
this/A={}
this/A<:b={}
this/A<:foo={}
this/B={B$0}
this/B<:foo={B$0->Foo$0}
skolem $foo_s={B$0}
skolem $foo_rel={B$0->B$0}
Когда мы go оцениваем, мы можем выполнить ваши количественные измерения шаг за шагом:
> univ-Foo
┌──┐
│B⁰│
└──┘
> (univ - Foo) -> (univ - Foo)
┌──┬──┐
│B⁰│B⁰│
└──┴──┘
Понятно, что при количественном определении по all rel: (univ - Foo) -> (univ - Foo)
это будет включать циклы.
> B⁰.*((univ - Foo) -> (univ - Foo))
┌──┐
│B⁰│
└──┘
Я думаю, что существует некоторое недопонимание того, как работают модели Alloy. Надеюсь, это поможет немного лучше изучить эти модели?