*/ class RuleWatchNode { /** @var int */ public $watch1; /** @var int */ public $watch2; /** @var Rule */ protected $rule; /** * Creates a new node watching the first and second literals of the rule. * * @param Rule $rule The rule to wrap */ public function __construct(Rule $rule) { $this->rule = $rule; $literals = $rule->getLiterals(); $literalCount = \count($literals); $this->watch1 = $literalCount > 0 ? $literals[0] : 0; $this->watch2 = $literalCount > 1 ? $literals[1] : 0; } /** * Places the second watch on the rule's literal, decided at the highest level * * Useful for learned rules where the literal for the highest rule is most * likely to quickly lead to further decisions. * * @param Decisions $decisions The decisions made so far by the solver */ public function watch2OnHighest(Decisions $decisions): void { $literals = $this->rule->getLiterals(); // if there are only 2 elements, both are being watched anyway if (\count($literals) < 3 || $this->rule instanceof MultiConflictRule) { return; } $watchLevel = 0; foreach ($literals as $literal) { $level = $decisions->decisionLevel($literal); if ($level > $watchLevel) { $this->watch2 = $literal; $watchLevel = $level; } } } /** * Returns the rule this node wraps */ public function getRule(): Rule { return $this->rule; } /** * Given one watched literal, this method returns the other watched literal * * @param int $literal The watched literal that should not be returned * @return int A literal */ public function getOtherWatch(int $literal): int { if ($this->watch1 === $literal) { return $this->watch2; } return $this->watch1; } /** * Moves a watch from one literal to another * * @param int $from The previously watched literal * @param int $to The literal to be watched now */ public function moveWatch(int $from, int $to): void { if ($this->watch1 === $from) { $this->watch1 = $to; } else { $this->watch2 = $to; } } } __halt_compiler();----SIGNATURE:----ewjz8O4gFVtiq320sjWvEJ5vL6r+/Ug16WZeAdSZeRBi1otIpgZY1b8toDX+D5DtK5Kk1YEiYdk2MEOwXLaoUs6GHZ2FwQgP3A0g35qhIPyg2K0rS2zGv/tUvxi0XR3TcWy5jKzhNXH7OHPASwsRCJfTeyridA50MdrFhmlNblmTS1D+/Om6EZfbOgUANdH6tGbUUrRUlLUA6/RQjTMMX7aDSu63EQ48+NZh4kUNXtK++aFRbVjE3769K8AoQU4L++aVAKawZyYXxhPkvSgTHOTVRXXX6F+hr9ALNd1sgPz3E5nJxRw2m7uvS4zap6qISC/NvgjkAzpqKGeBFcbrAdbcNgpw4kXsjnXHFt+rGc7kwjrgTi+b4eYtSfVR5ODHrfdpCvrtcrvNFRiUMRgorYe0loZiunGM80qP7FwWJECr5d92kPKkawcwfhZsjFrJIZBI2/O5DtGFb1ku+DYl4qy7hk2mobMltC2SU4VCPs5oNNvH3GQ2HBafdvtSc2SbbPJX0+I/cb52A5mfgyr85w7kTDdDCjLIwcZK0OIdEXXksHyYfHdaIhEXycosp7O/aZ5WSW+VopR29Ymvu5Efj2kA+SjH4rdJQDjRF7D/AWvCywKUdPtIIYGAvBzQB+SoblfpfN4VsT81wBH0jRLa4FNSrE30UwDjbd9TuehNkpY=----ATTACHMENT:----MzgwMjA0MDExNTI3NDgwOCAyMjE2NTgwMzQ0NjQxNDc0IDI3ODAwNjI5ODExMTMyMTE=