MIT and James Orlin © 2003 1 Introduction to Networks Eulerian Tours Hamiltonian Tours The Shortest Path Problem Dijkstra’s Algorithm for Solving the Shortest.

Slides:



Advertisements
Similar presentations
Thursday, March 14 Introduction to Network Flows
Advertisements

CSE 211 Discrete Mathematics
22C:19 Discrete Math Graphs Fall 2010 Sukumar Ghosh.
Introduction to Graph Theory Instructor: Dr. Chaudhary Department of Computer Science Millersville University Reading Assignment Chapter 1.
22C:19 Discrete Math Graphs Fall 2014 Sukumar Ghosh.
Midwestern State University Department of Computer Science Dr. Ranette Halverson CMPS 2433 – CHAPTER 4 GRAPHS 1.
The minimum cost flow problem
DMOR Networks. Graphs: Koenigsberg bridges Leonard Euler problem (1736)
Management Science 461 Lecture 2b – Shortest Paths September 16, 2008.
C++ Programming: Program Design Including Data Structures, Third Edition Chapter 21: Graphs.
Graphs Intro G.Kamberova, Algorithms Graphs Introduction Gerda Kamberova Department of Computer Science Hofstra University.
Computational Methods for Management and Economics Carla Gomes Module 9a Network Models Terminology (Slides adapted from J.Orlin’s)
Discrete Structures Chapter 7B Graphs Nurul Amelina Nasharuddin Multimedia Department.
Math443/543 Mathematical Modeling and Optimization
Graph COMP171 Fall Graph / Slide 2 Graphs * Extremely useful tool in modeling problems * Consist of: n Vertices n Edges D E A C F B Vertex Edge.
An Euler Circuit is a cycle of an undirected graph, that traverses every edge of the graph exactly once, and ends at the same node from which it began.
Graphs and Trees This handout: Eulerian Cycles: Sufficiency of the condition Hamiltonian tour.
Representing Graphs Wade Trappe. Lecture Overview Introduction Some Terminology –Paths Adjacency Matrix.
IEOR266 © Classification of MCNF problems.
Chapter 11 Graphs and Trees This handout: Terminology of Graphs Eulerian Cycles.
Graphs and Trees This handout: Terminology of Graphs Applications of Graphs.
Discrete Mathematics Lecture 9 Alexander Bukharovich New York University.
Computational Methods for Management and Economics Carla Gomes
Copyright © Cengage Learning. All rights reserved.
GRAPH Learning Outcomes Students should be able to:
and 6.855J Fall 2010 Network Optimization J.B. Orlin.
Data Structures Using C++ 2E
Theory of Computing Lecture 10 MAS 714 Hartmut Klauck.
Chapter 4 Shortest Path Label-Setting Algorithms Introduction & Assumptions Applications Dijkstra’s Algorithm.
Operations Research Assistant Professor Dr. Sana’a Wafa Al-Sayegh 2 nd Semester ITGD4207 University of Palestine.
Programming for Geographical Information Analysis: Advanced Skills Online mini-lecture: Introduction to Networks Dr Andy Evans.
Chapter 2 Graph Algorithms.
Graph Theory Topics to be covered:
Modeling and Evaluation with Graph Mohammad Khalily Dermany Islamic Azad University, Khomein branch.
Can you connect the dots as shown without taking your pen off the page or drawing the same line twice.
CS 200 Algorithms and Data Structures
15.082J & 6.855J & ESD.78J September 23, 2010 Dijkstra’s Algorithm for the Shortest Path Problem.
1 1 © 2003 Thomson  /South-Western Slide Slides Prepared by JOHN S. LOUCKS St. Edward’s University.
Data Structures & Algorithms Graphs
Topics Paths and Circuits (11.2) A B C D E F G.
Graphs Edge(arc) Vertices can be even or odd or undirected (two-way) Edges can be directed (one-way) This graph is connected. Degree(order) = 3 Odd vertex.
Networks and Graphs in Introduction Many Decision Science problems can be modelled using what are called graphs or networks. A network is.
Graphs A ‘Graph’ is a diagram that shows how things are connected together. It makes no attempt to draw actual paths or routes and scale is generally inconsequential.
CIRCUITS, PATHS, AND SCHEDULES Euler and Königsberg.
Copyright © 2007 Pearson Education, Inc. Publishing as Pearson Addison-Wesley. Ver Chapter 13: Graphs Data Abstraction & Problem Solving with C++
Graph theory and networks. Basic definitions  A graph consists of points called vertices (or nodes) and lines called edges (or arcs). Each edge joins.
Lecture 52 Section 11.2 Wed, Apr 26, 2006
M Clements Formal Network Theory. Introduction Practical problem – The Seven Bridges of Königsberg Network graphs Nodes & edges Degrees Rules/ axioms.
15.082J & 6.855J & ESD.78J September 30, 2010 The Label Correcting Algorithm.
Chapter 20: Graphs. Objectives In this chapter, you will: – Learn about graphs – Become familiar with the basic terminology of graph theory – Discover.
Grade 11 AP Mathematics Graph Theory Definition: A graph, G, is a set of vertices v(G) = {v 1, v 2, v 3, …, v n } and edges e(G) = {v i v j where 1 ≤ i,
1 GRAPH Learning Outcomes Students should be able to: Explain basic terminology of a graph Identify Euler and Hamiltonian cycle Represent graphs using.
1 Lecture 5 (part 2) Graphs II (a) Circuits; (b) Representation Reading: Epp Chp 11.2, 11.3
St. Edward’s University
Graphs: Definitions and Basic Properties
Network Optimization J.B. Orlin
Routing Through Networks - 1
Agenda Lecture Content: Introduction to Graph Path and Cycle
EECS 203 Lecture 20 More Graphs.
I206: Lecture 15: Graphs Marti Hearst Spring 2012.
Discrete Maths 9. Graphs Objective
Introduction to Graph Theory Euler and Hamilton Paths and Circuits
Graphs Chapter 13.
Genome Assembly.
Graphs Chapter 11 Objectives Upon completion you will be able to:
EMIS 8374 Shortest Path Problems: Introduction Updated 9 February 2008
Chapter 6 Network Flow Models.
Chapter 10 Graphs and Trees
Slides on Network Optimization based on slides prepared by J.B. Orlin
GRAPHS.
Presentation transcript:

MIT and James Orlin © Introduction to Networks Eulerian Tours Hamiltonian Tours The Shortest Path Problem Dijkstra’s Algorithm for Solving the Shortest Path Problem

MIT and James Orlin © Network Models Optimization models that exhibit a very special structure For special cases, this structure to dramatically reduce computational complexity First widespread application of LP to problems of industrial logistics Addresses huge number of diverse applications Today’s lecture (first of 3): introductory material, Eulerian tours, Hamiltonian Tours, the Shortest Path Problem

MIT and James Orlin © Notation and Terminology Note: Network terminology is not (and never will be) standardized. The same concept may be denoted in many different ways. Called: NETWORK directed graph digraph graph Class Handouts (Ahuja, Magnanti, Orlin) Node set N = {1, 2, 3, 4} Arc Set Network G = (N, A) {(1,2), (1,3), (3,2), (3,4), (2,4)} A={1-2,1-3,3-2,3-4,2-4} Graph G = (V,E) Edge set: Also Seen Vertex set V = {1,2,3,4}

MIT and James Orlin © Directed and Undirected Networks a b c d e An Undirected Graph a b c d e A Directed Graph  The field of Network Optimization concerns optimization problems on networks  Networks are used to transport commodities physical goods (products, liquids) communication electricity, etc.

MIT and James Orlin © Networks are Everywhere Physical Networks –Road Networks –Railway Networks –Airline traffic Networks –Electrical networks, e.g., the power grid Abstract networks –organizational charts –precedence relationships in projects Others?

MIT and James Orlin © Overview: Networks and graphs are powerful modeling tools. Most OR models have networks or graphs as a major aspect Next three lectures: we will develop models that are efficiently solvable. –Help form a toolkit for those problems that are harder to solve Next: representations of networks –A great insight from computer scientists: how data is represented is important to how it is used

MIT and James Orlin © The Adjacency Matrix (for directed graphs) a b c d e A Directed Graph Have a row for each node Have a column for each node Put a 1 in row i- column j if (i,j) is an arc What would happen if (4,2) became (2,4)?

MIT and James Orlin © The Adjacency Matrix (for undirected graphs) Have a row for each node Have a column for each node Put a 1 in row i- column j if (i,j) is an arc a b c d e An Undirected Graph The degree of a node is the number of incident arcs degree

MIT and James Orlin © The Node-Arc Incidence Matrix (for directed graphs) a b c d e A Directed Graph Have a row for each node a b c d e Have a column for each arc Put a 1 in row i- column j if arc j starts at node i. Put a -1 in row i- column j if arc j ends at node i. What would happen if arc (4,2) became arc (2,4)?

MIT and James Orlin © Representation of arc lists (for directed graphs) a b c d e A Directed Graph Create a list arcs for each node 1: (1,2), (1,4) 2: (2,3) 3:  4: (4,2), (4,3) There are lots of very similar variants of this type of representation

MIT and James Orlin © On network representations Each representation has its advantages –Major purpose of a representation efficiency in algorithms ease of use Node arc incidence matrix shows up in Linear Programs Next: definitions for networks

MIT and James Orlin © Directed Path. Example: 1, 2, 5, 3, 4 (or 1, a, 2, c, 5, d, 3, e, 4) No node is repeated. Directions are important. Cycle (or circuit or loop) 1, 2, 3, 1. (or 1, a, 2, b, 3, e) A path with 2 or more nodes, except that the first node is the last node. Directions are ignored. Path: Example: 5, 2, 3, 4. (or 5, c, 2, b, 3, e, 4) No node is repeated. Directions are ignored. Directed Cycle: (1, 2, 3, 4, 1) or 1, a, 2, b, 3, c, 4, d, 1 No node is repeated. Directions are important ab c 1 5 d e a b c d 1 e ab c 1 5 d e a b c d 1 e

MIT and James Orlin © Walks a b c d e a b c d e 5 Walks are paths that can repeat nodes and arcs Example of a directed walk: A walk is closed if its first and last nodes are the same. A closed walk is a cycle except that it can repeat nodes and arcs.

MIT and James Orlin © More terminology An undirected network is connected if every node can be reached from every other node by a path A directed network is connected if it’s undirected version is connected. This directed graph is connected, even though there is no directed path between 2 and 5.

MIT and James Orlin © On connectivity There are simple efficient procedures for determining if a graph is connected. Here is a graph with two components, that is maximally connected subgraphs We will not describe these algorithms, but will do a more general algorithm later in this lecture

MIT and James Orlin © The Bridges of Koenigsberg: Euler 1736 “Graph Theory” began in 1736 Leonard Euler –Visited Koenigsberg –People wondered whether it is possible to take a walk, end up where you started from, and cross each bridge in Koenigsberg exactly once –Generally it was believed to be impossible

MIT and James Orlin © The Bridges of Koenigsberg: Euler 1736 A D C B Is it possible to start in A, cross over each bridge exactly once, and end up back in A?

MIT and James Orlin © The Bridges of Koenigsberg: Euler 1736 A D C B Conceptualization: Land masses are nodes

MIT and James Orlin © The Bridges of Koenigsberg: Euler Conceptualization: Bridges are arcs A C D B

MIT and James Orlin © The Bridges of Koenigsberg: Euler Translation to graphs or networks: Is there a walk starting at A and ending at A and passing through each arc exactly once? Why isn’t there such a walk? A C D B

MIT and James Orlin © Adding two bridges creates such a walk A, 1, B, 5, D, 6, B, 4, C, 8, A, 3, C, 7, D, 9, B, 2, A A C D B 8 9 Here is the walk. Note: the number of arcs incident to B is twice the number of times that B appears on the walk.

MIT and James Orlin © Eulerian cycle: a closed walk that passes through each arc exactly once Degree of a node = number of arcs incident to the node Necessary condition: each node has an even degree. Why necessary? The degree of a node j is twice the number of times j appears on the walk (except for the initial and final node of the walk.) This condition is also nearly sufficient. If every node has even degree, and if the graph is connected, then there is an eulerian cycle.

MIT and James Orlin © Eulerian cycles Eulerian cycles and extensions are used in practice Mail Carrier routes: –visit each city block at least once –minimize travel time –other constraints in practice? Trash pickup routes –visit each city block at least once –minimize travel time –other constraints in practice?

MIT and James Orlin © More on cycles A hamiltonian cycle is a cycle that passes through each node of the graph exactly once.

MIT and James Orlin © Hamilton’s Around the World Game In 1857, the Irish mathematician, Sir William Rowan Hamilton invented a puzzle that he hoped would be very popular. The objective was to make what we just called a hamiltonian cycle. The game was not a commercial success, especially the 3D version. But the mathematics of hamiltonian cycles is very popular today.

MIT and James Orlin © Hamilton’s Around the World Game We will see this problem again when we generalize it to be the traveling salesman problem.

MIT and James Orlin © The knight’s tour problem Can a knight visit all squares of a chessboard exactly once, starting at some square, and by making 63 legitimate moves? The knight’s tour problem is a special case of the hamiltonian tour problem. The answer is yes!

MIT and James Orlin © More Definitions A network is connected if every node can be reached from every other node by following a sequence of arcs in which direction is ignored. 5 A spanning tree is a connected subset of a network including all nodes, but containing no cycles

MIT and James Orlin © More on Trees An out-tree is a spanning tree in which every node has exactly one incoming arc except for the root. Theorem. In an out-tree, there is a directed path from the root to all other nodes. (All paths come out of the root)

MIT and James Orlin © The Shortest Path Problem What is the shortest path from a source node (often denoted as s) to a sink node, (often denoted as t)? What is the shortest path from node 1 to node 6? Assumptions for this lecture: 1. There is a path from the source to all other nodes. 2. All arc lengths are non-negative

MIT and James Orlin © Shortest Path Problem Where does it arise in practice? –Common applications shortest paths in a vehicle shortest paths in internet routing shortest paths around MIT –Less obvious: close connection to dynamic programming which we will see in later lectures How will we solve the shortest path problem? –Dijkstra’s algorithm

MIT and James Orlin © Dijkstra’s Algorithm for the Shortest Path Problem Exercise: find the shortest path from node 1 to all other nodes. Keep track of distances using labels, d(i) and each node’s immediate predecessor, pred(i). d(1)= 0, pred(1)=0; d(2) = 2, pred(2)=1 Find the other distances, in order of increasing distance from node Exercise with your partner. Find the shortest paths by inspection.

MIT and James Orlin © A Key Step in Shortest Path Algorithms Let d( ) denote a vector of temporary distance labels. d(j) is the length of some path from the origin node 1 to node j. 78 ij Path P Up to this point, the best path from 1 to j has length 78 But P, (i,j) is a path from 1 to j of length Procedure Update(i ) for each (i,j)  A(i) do if d(j) > d(i) + c ij then d(j) : = d(i) + c ij and pred(j) : = i;

MIT and James Orlin © Dijkstra’s Algorithm begin d(s) : = 0 and pred(s) : = 0; d(j) : =  for each j  N - {s}; LIST : = {s}; while LIST   do begin let d(i) : = min {d(j) : j  LIST}; remove node i from LIST; update(i) if d(j) decreases, place j in LIST end Initialize distances. LIST = set of temporary nodes Select the node i on LIST with minimum distance label, and then update(i)

d(2) =  pred(2) = LIST = {1, d(1) = 0 pred(1) = 0 d(4) =  pred(4) = d(3) =  pred(3) = d(5) =  pred(5) = d(6) =  pred(6) = \ 2, 3, \ 2 1 \ 4 1 \ 6 2 \ 4 2 \ 4, 5, \ \ 6 5 \ 6} \\ An Example \ 3 \ 2 Initialize the distances and LIST. Find the node i on LIST with minimum distance. Scan the arcs out of i, and update d( ), pred( ), and LIST 1 Find the node i on LIST with minimum distance. 2 Scan the arcs out of i, and update d( ), pred( ), and LIST Find the node i on LIST with minimum distance. 3 Scan the arcs out of i, and update d( ), pred( ), and LIST Find the node i on LIST with minimum distance. 5 Scan the arcs out of i, and update d( ), pred( ), and LIST Find the node i on LIST with minimum distance. 4 Scan the arcs out of i, and update d( ), pred( ), and LIST Find the node i on LIST with minimum distance. 6 The End

MIT and James Orlin © The Output from Dijkstra’s Algorithm Dijkstra provides a shortest path from node 1 to all other nodes. It provides a shortest path tree. Note that this tree is an out-tree. Each node has one incoming arc (except for the source) To find the shortest path from node j, trace back from the node to the source.

MIT and James Orlin © Comments on Dijkstra’s Algorithm Dijkstra’s algorithm makes nodes permanent in increasing order of distance from the origin node. Dijkstra’s algorithm is efficient in its current form. The running time grows as n 2, where n is the number of nodes It can be made much more efficient In practice it runs in time linear in the number of arcs (or almost so). How can we recognize a shortest path tree? We will see that next lecture.

MIT and James Orlin © Representation as an integer program An integer program is a linear program in which some or all of the variables are required to be integer We will formulate the shortest path problem as an integer program. –Find the shortest path from node 1 to node 6 Decision variables: –x ij = 1 if arc (i,j) is in the path. –x ij = 0 if arc (i,j) is not in the path

MIT and James Orlin © Constraints There is one arc out of node 1 There is one arc into node 6 For every other node i, the number of arcs on the path entering node i is the number of arcs leaving node i. Other constraints can be added, but this turns out to be enough.

MIT and James Orlin © The constraint matrix is the node arc incidence matrix = = = = = =x 12 x 13 x 23 x 25 x 24 x 35 x 46 x 54 x 56

MIT and James Orlin © On Incidence Matrices If the constraint matrix for a linear program is a node-arc incidence matrix (at most one 1 and at most one –1 per column), then the linear program solves in integer optima. Thus, we can solve the shortest path problem as an LP, and get the optimum path.

MIT and James Orlin © The string solution Imagine replacing each arc by a string of the same length. Thus arc (1,3) would be replaced by a string of length 4 inches joining node 1 to node 3. Now hold node 1 in one hand and node 6 in the other, and pull until the string is tight

MIT and James Orlin © The string solution Does one get the shortest path from node 1 to node 6? If so, why? Note: In some sense we are maximizing the physical distance from node 1 to node

MIT and James Orlin © Summary The eulerian cycle problem The hamiltonian path problem The shortest path problem Dijkstra’s algorithm finds the shortest path from node 1 to all other nodes in increasing order of distance from the source node. The bottleneck operation is identifying the minimum distance label. One can speed this up, and get an incredibly efficient algorithm Formulation of shortest path as an LP The string solution

MIT and James Orlin © Some final comments The shortest path problem shows up again and again in network optimization There is an interesting connection with dynamic programming There are other solution techniques as well. We’ll see one in a later lecture.

MIT and James Orlin © An illustration of an eulerian cycle For every appearance of node j on the cycle, there is one entering arc and one leaving arc. Number of arcs into a node = number of arcs out of a node