过渡系统中的错误(行为)JaCaMo / Jason的情况

时间:2018-05-14 20:53:24

标签: agent multi-agent

尝试发送untell消息时遇到错误。我写了一个简单的项目来解释:当bob发送一条untell消息时,转换系统中出现错误。是否有可能通过untell删除信仰?那么,如何发送呢?

鲍勃的代码:

!start.

+!start <- 
    .print("Starting...");
    .send(alice, tell, hi).

+hi <- 
    .print("Hi");
    .send(alice, tell, marryMe).

+yes <-
    .print("No no..."); 
    .send(alice, untell, marryMe).


{ include("$jacamoJar/templates/common-cartago.asl") }
{ include("$jacamoJar/templates/common-moise.asl") }

Alice的代码:

+hi <- 
    .print("Hi");
    .send(bob, tell, hi).

+marryMe <- 
    .print("Yes!");
    .send(bob, tell, yes).

-marryMe <- .print("Humm?").

{ include("$jacamoJar/templates/common-cartago.asl") }
{ include("$jacamoJar/templates/common-moise.asl") }

项目:

mas jacamotest {

    agent bob

    agent alice

}

Jacamo的输出:

CArtAgO Http Server running on http://X.X.X.X:3273
Jason Http Server running on http://X.X.X.X:3272
[bob] Starting...
[alice] Hi
[bob] Hi
[alice] Yes!
[bob] No no...
[ArithExpr] The value of (-NS::CA) is not a number! Unifier = {Sender=bob, NS=default, Content=marryMe, _42=mid5,
CA=marryMe[source(bob)]}. Code: kqmlPlans.asl:43
[alice] *** ERROR in the transition system (act). Circumstance:
  E =[]
  I =[]
  A =null
  MB=[]
  RP=null
  AP=null
  SE=+!kqml_received(bob,untell,marryMe,mid5)
  SO=(@kqmlReceivedUnTell[source(self)] +!kqml_received(Sender,untell,NS::Content,_42) <- .add_nested_source(Content,Sender,CA); -(-NS::CA).,{Sender=bob,
  NS=default, Content=marryMe, _42=mid5, CA=marryMe[source(bob)]})
  SI=intention 6: 
    +!kqml_received(bob,untell,marryMe,mid5) <- ... -(-NS::CA) / {Sender=bob, NS=default, Content=marryMe, _42=mid5,
  CA=marryMe[source(bob)]}

  AI=null
  AE=null
  PA={}
  PI={}
  FA=[].
Creating a new C!
java.lang.ClassCastException: jason.asSyntax.NumberTermImpl cannot be cast to jason.asSyntax.Literal
  at jason.asSemantics.TransitionSystem.prepareBodyForEvent(TransitionSystem.java:932)
  at jason.asSemantics.TransitionSystem.applyExecInt(TransitionSystem.java:907)
  at jason.asSemantics.TransitionSystem.applySemanticRuleAct(TransitionSystem.java:237)
  at jason.asSemantics.TransitionSystem.act(TransitionSystem.java:1525)
  at jason.infra.centralised.CentralisedAgArch.act(CentralisedAgArch.java:203)
  at jason.infra.centralised.CentralisedAgArch.reasoningCycle(CentralisedAgArch.java:212)
  at jason.infra.centralised.CentralisedAgArch.run(CentralisedAgArch.java:231)
  at java.base/java.lang.Thread.run(Thread.java:844)

1 个答案:

答案 0 :(得分:3)

这是由于SNAPSHOT版本中的错误。新的jason-2.3-SNAPSHOT正在修复它。