1 / 14

Optimally Modifying Software for Safety and Functionality

Explore optimizing software for safety and desired functionality while considering system redesign and control costs. Learn about FSM models, control strategies, and dynamic programming solutions.

pbuehler
Download Presentation

Optimally Modifying Software for Safety and Functionality

An Image/Link below is provided (as is) to download presentation Download Policy: Content on the Website is provided to you AS IS for your information and personal use and may not be sold / licensed / shared on other websites without getting consent from its author. Content is provided to you AS IS for your information and personal use only. Download presentation by click this link. While downloading, if for some reason you are not able to download a presentation, the publisher may have deleted the file from their server. During download, if you can't get a presentation, the file might be deleted by the publisher.

E N D

Presentation Transcript


  1. Optimally Modifying Software for Safety and Functionality Sampath Kannan U.Penn (with Arvind Easwaran & Insup Lee)

  2. Introduction • User requirements on software systems • Desired functionality • Safety properties • Verification/validation used to locate safetyviolations • What about static correction of errors bysystem redesign?

  3. Desirable Features of Model • System redesign must preserve functionality: reward functionality, penalize violations • System model must be stochastic becauseof interaction with unpredictable environment • Each redesign/system control incurs a control cost.

  4. System Model • Software system represented by a finite state machine (FSM) • Probability on transitions abstracts stochasticity • Cost of control associated with blocking transitions • Uncontrollable transitions explicitly labeled • Numeric rewards and penalties at the states

  5. System Model – cont’d 20 -200 10 .5 a q0 q1 25 .3 b 30 .2 c q2 q3 100 Goal: Control transitions to maximize difference betweenexpected reward and control cost. Only consider the static version of the problem here.

  6. DBMS Concurrency Controller • Concurrency controller controls execution of transactions • Transaction i can read/writedata items • Commit ci indicates i is complete • Serializable schedule – schedule equivalent to sequential execution of transactions

  7. DBMS Controller as FSM • States = set of active transactions with state for each • Transitions = read/write/commit • Stochasticity = which transaction chosen • Control cost = increased latency • Reward = completed transaction • Violation = non-serializability

  8. Wireless Network Routing • Message routing in wireless ad-hoc networks • Each wireless node capable of communicating • with a fixed set of nodes called its neighbors • Nodes communicate by broadcasting messages • Depending on the operating environment, only • some of the neighbors would be able to receive • the broadcast • At each stage, routing algorithm chooses a node • for transmission

  9. Network Routing (2) • State: Set of wireless nodes with the message • Transition: Transmission by a particular node • and reception by some of its neighbors • Control action: Preventing the router from • selecting some nodes • Stochasticity: Uncertainty in reception of • message transmitted by a neighbor • Penalty: Cost of transmission • Rewards: Reward for reception of message by a • destination node

  10. Mathematical Notation A: Control policy specifying blocked trans’ns. p(u,v) : Probability of transition (u,v) cA(u,v): Cost of controlling (u,v) under A. r(i): Reward/penalty at state i

  11. Goal • Want to pick control strategy A (i.e. whichtransitions to suppress) to minimize expected cost. • Challenge: Transition probabilities are dynamic... suppressing one transition increases probabilities of others

  12. Solution Technique - DAGs • If FSM is directed acyclic graph (DAG) • Dynamic programming algorithm computes optimal strategy efficiently • Starting from the sink nodes k, compute Ek up the DAG. • When computing Ei if suppressing some transition (i,j) improves Eido it.

  13. Arbitrary Graphs • Unique solution might not exist – switch to discounted rewards to ensure it does. • Write constraints for each possible subset of transitions controlled – exponential number of constraints! • Use implicit Linear Programming Solver such as Ellipsoid Algorithm to find optimum in polynomial time.

  14. Conclusion • Abstracted software systems as a stochastic FSM • with cost of control, rewards and penalties • Developed polynomial time DP algorithm for • directed acyclic graphs • Formulated optimization problem for strongly • connected components as a LPP • Described polynomial time separation oracle • thereby generating polynomial time ellipsoid • algorithm

More Related