1.82k likes | 1.93k Views
Quantitative Languages: Weighted Automata and Beyond. Laurent Doyen LSV, ENS Cachan & CNRS. Credits. This talk is based on joint work with…. K. Chatterjee, H. Edelsbrunner, T. A. Henzinger (IST Austria) A. Degorre, J.-F. Raskin (ULB Brussels) R. Gentilini (Uni. Perugia)
E N D
Quantitative Languages: Weighted Automata and Beyond Laurent DoyenLSV, ENS Cachan & CNRS
Credits This talk is based on joint work with… • K. Chatterjee, H. Edelsbrunner, T. A. Henzinger (IST Austria) • A. Degorre, J.-F. Raskin (ULB Brussels) • R. Gentilini (Uni. Perugia) • S. Torunczyk (Uni. Warsaw) • P. Rannou (ENS Cachan) (CSL’08, LICS’09, FCT’09, CSL’10, Concur’10)
Model-Checking Program/ System Property/ Specification Satisfaction Relation Yes / No -perhaps a proof -perhaps some counterexamples
Model-Checking Program/ System Property/ Specification Formula Every request is followed by a grant Finite-state machine Trace inclusion Yes / No
Model-Checking Program/ System Property/ Specification Formula Every request is followed by a grant Finite-state machine Trace inclusion Yes / No Model-checking is boolean • a trace is either good or bad • a system is either good or bad
Quantitative Analysis Program/ System Property/ Specification Formula Every request is followed by a grant Finite-state machine Quantitative Analysis Value (R) • Measure of “fit” between system and spec • e.g. average number of requests immediately granted
Quantitative Analysis Program/ System #1 Program/ System #2 Finite-state machine Every request is followed by a grant Quantitative Analysis Distance (R) • Comparing two implementations • e.g. cost or quality measure
Quantitative Model-checking Is there a Quantitative Framework with - an appealing mathematical formulation, - useful expressive power, robustness and - good algorithmic properties ? (Like the boolean theory of -regularity.) Note: “Quantitative” is more than “timed” and “probabilistic”
Quantitative languages A language is a boolean function:
Quantitative languages A language is a boolean function: A quantitative language is a function: • L(w) can be interpreted as: • the amount of some resource needed by thesystem to produce w (power, energy, time consumption), • a reliability measure (the average number of “faults” in w).
Quantitative languages Quantitative language inclusion Is LA(w) LB(w) for all words w ? LA(w) peak resource consumption Long-run average response time LB(w) resource bound a Average response-time requirement
Quantitative languages Quantitative language inclusion Is LA(w) LB(w) for all words w ? Distance: LA(w) peak resource consumption Long-run average response time LB(w) resource bound a Average response-time requirement
Outline • Motivation • Weighted automata • Decision problems • Expressive power • Closure properties • Beyond weighted automata
Automata Boolean languages are generated by finite automata. Nondeterministic Büchi automaton
Automata Boolean languages are generated by finite automata. Nondeterministic Büchi automaton Value of a run r: Val(r)= 1if an accepting state occurs -ly often in r 0 otherwise
Automata Boolean languages are generated by finite automata. Nondeterministic Büchi automaton Value of a run r: Val(r)= 1if an accepting state occurs -ly often in r Value of a word w: sup of {values of the runs r over w}
Automata Boolean languages are generated by finite automata. Nondeterministic Büchi automaton LA(w) = sup of {Val(r) | r is a run of A over w}
Weighted automata Weight function Quantitative languages are generated by weighted automata.
Weighted automata Weight function where is a value function Quantitative languages are generated by weighted automata. Value of a word w: sup of {values of the runs r over w} Value of a run r: Val(r)
Some value functions (vi {0,1}) (reachability) (Büchi) (coBüchi)
Some value functions (vi {0,1}) (reachability) (Büchi) (coBüchi)
Example: a motor Specification Deterministic LimAvg automaton
Example: a motor Implementation(refined spec.) Specification
Example: a motor Implementation(refined spec.) Specification
Example: a motor Implementation(refined spec.) Specification
Example: a motor Implementation(refined spec.) Specification
Example: a motor Implementation(refined spec.) Specification
Example: a motor Implementation(refined spec.) Specification In the long-run, implementation has average cost cheaper than specification (for all traces).
Outline • Motivation • Weighted automata • Decision problems • Expressive power • Closure properties • Beyond weighted automata
Emptiness • decidable in polynomial time for Given , is LA(w) ≥ for some word w ? • solved by finding the maximal value of an infinite path in the graph of A, • memoryless strategies exist in the corresponding quantitative 1-player games,
Language Inclusion Is LA(w) LB(w) for all words w ? • PSPACE-complete for • equivalent to
Language Inclusion Is LA(w) LB(w) for all words w ? • PSPACE-complete for • Solvable in polynomial-time when B is deterministic for and , • undecidable for nondeterministic automata. • open question for nondeterministic automata.
Language-inclusion game Language inclusion as a game Discounted-sum automata, λ=3/4 Is LA(w) LB(w) for all words w ?
Language-inclusion game Language inclusion as a game Discounted-sum automata, λ=3/4 Yes ! Is LA(w) LB(w) for all words w ?
Language-inclusion game Language inclusion as a game • turn-based, two players; • Challenger wins iff Is LA(w) LB(w) for all words w ?
Language-inclusion game Language inclusion as a game • turn-based, two players; • Challenger wins iff winning strategy Is LA(w) LB(w) for all words w ?
Language-inclusion game Language inclusion as a game Tokens on the initial states
Language-inclusion game Language inclusion as a game Challenger constructs a run r1 of A, Simulator constructs a run r2 of B. Challenger wins if Val(r1) > Val(r2). Challenger: Simulator:
Language-inclusion game Language inclusion as a game Challenger: Simulator:
Language-inclusion game Language inclusion as a game Challenger: Simulator:
Language-inclusion game Language inclusion as a game Challenger: Simulator:
Language-inclusion game Language inclusion as a game Challenger: Simulator:
Language-inclusion game Language inclusion as a game Challenger: Simulator:
Language-inclusion game Language inclusion as a game Challenger: Simulator:
Language-inclusion game Language inclusion as a game Challenger: Simulator:
Language-inclusion game Language inclusion as a game Challenger wins since 4>2. However, LA(w) LB(w) for all w. Challenger: Simulator:
Language-inclusion game The game is blind if the Challenger cannot observethe state of the Simulator. Challenger has no winning strategy in the blind game if and only if LA(w) LB(w) for all words w.
Language-inclusion game The game is blind if the Challenger cannot observe the state of the Simulator. Challenger has no winning strategy in the blind game if and only if LA(w) LB(w) for all words w. When the game is not blind, we say that BsimulatesA if the Challenger has no winning strategy. Simulation implies language inclusion.