Я использую имитатор дискретных событий ns-2, созданный с использованием Tcl и C ++. Я пытался написать код в TCL:
set ns [new Simulator]
set state 0
$ns at 0.0 "puts \"At 0.0 value of state is: $state\""
$ns at 1.0 "changeVal"
$ns at 2.0 "puts \"At 2.0 values of state is: $state\""
proc changeVal {} {
global state
global ns
$ns at-now "set state [expr $state+1]"
puts "Changed value of state to $state"
}
$ns run
Вот вывод:
At 0.0 value of state is: 0
Changed value of state to 0
At 2.0 values of state is: 0
Значение состояния, похоже, не меняется. Я не уверен, что делаю что-то не так при использовании TCL. Кто-нибудь имеет представление о том, что здесь может пойти не так?
РЕДАКТИРОВАТЬ: Спасибо за помощь. На самом деле, ns-2 - это то, над чем у меня нет особого контроля (если я не перекомпилирую симулятор). Я опробовал предложения и вот вывод:
для кода:
set ns [new Simulator]
set state 0
$ns at 0.0 "puts \"At 0.0 value of state is: $state\""
$ns at 1.0 "changeVal"
$ns at 9.0 "puts \"At 2.0 values of state is: $state\""
proc changeVal {} {
global ns
set ::state [expr {$::state+1}]
$ns at-now "puts \"At [$ns now] changed value of state to $::state\""
}
$ns run
вывод:
At 0.0 value of state is: 0
At 1 changed value of state to 1
At 2.0 values of state is: 0
А для кода:
set ns [new Simulator]
set state 0
$ns at 0.0 "puts \"At 0.0 value of state is: $state\""
$ns at 1.0 "changeVal"
$ns at 9.0 "puts \"At 2.0 values of state is: $state\""
proc changeVal {} {
global ns
set ::state [expr {$::state+1}]
$ns at 1.0 {puts "At 1.0 values of state is: $::state"}
}
$ns run
вывод:
At 0.0 value of state is: 0
At 1.0 values of state is: 1
At 2.0 values of state is: 0
Кажется, не работает ... Не уверен, что это проблема с ns2 или моим кодом ...