6.01 Final Exam: Spring 2009: Name
6.01 Final Exam: Spring 2009: Name
6.01 Final Exam: Spring 2009: Name
Name:
For staff use: 1. 2. 3. 4. 5. 6. 7. total: /14 /14 /14 /14 /15 /14 /15 /100
worksheet
a0 x0 + ... + an xn = c
with a list of coefcients, coeffs, corresponding to [a0 , ..., an ] and the constant, c.
class Equation: def __init__(self, coeffs, variableNames, self.variableNames = variableNames self.coeffs = coeffs self.constant = constant constant):
# List of variable names
# List of coefficients
# Constant (right hand side)
Suppose that we had a list of values of [v0, ..., vn] for the variables (x0 , ... xn ) in which one of the values is None and all of the rest of the values are numbers. These numeric values are enough to determine a value for the unspecied variable. Write a procedure determineValue that takes an instance of the Equation class and a list of values (exactly one of which is None) and returns the value of the unspecied variable.
def determineValue(eq, values): ans = eq.constant for i in range(len(eq.coeffs)): if values[i] == None: a = eq.coeffs[i] else: ans -= eq.coeffs[i]*values[i] return ans/float(a)
R V1 V2 R Vo R
R R
Notice that if we knew the values of Vo and V2 then we could calculate the value of V . The resulting value of V will be a linear combination of V2 and Vo of the following form:
V = Vo + V2 .
(1)
Part a. Use Equation 1 to nd an expression for the output voltage Vo in terms of the input voltages V1 and V2 . Which of the following expressions gives the result? Hint: it is not necessary to determine the values of and to do this part of the question.
VA = V2 V1 VD = V2 V1
VB = VE = VH = VK =
V2 V1 V2 V1 V1 V2 V1 V2
VC = V2 V1 VF = V2 V1
VG = V1 V2 VJ = V1 V2
VI = V1 V2 VL = V1 V2
VL
6.01 Final Exam Spring 09 Part b. Find and in Equation 1 (previous page). Hint: Try superposition.
1 5
3 5
Vo R R R R V
1 V = Vx 2
Vx =
2 R 2R||R 2 Vo = 3 2 Vo = Vo R + 2R||R 5 R + 3R
Also, if Vo = 0 then V = V2 .
R V2 R V
V =
3 2R V2 + 3R 2
3 = V2 5
Part c. Combine the results of parts a and b to determine an expression for Vo in terms of V1 and V2 .
Vo =
Vo =
Grading: 4 points for part a; 4 points for ; 4 points for ; 2 points for part c.
hasNode - given a node, returns True when the node exists in the graph and false otherwise. addNode - given a node, if its not already present, it adds it to the graph, initially with no edges.
addEdge - given two nodes, add a connection from the rst to the second. If either node is not
already present, it is added to the graph.
children - given a node, returns a list of nodes that can be reached from that node by travers
ing a single arc. If the node is not present, it returns an empty list.
Here is an example use:
>>> g = DirectedGraph()
>>> g.addNode(A)
>>> g.addEdge(A,B)
>>> g.children(A)
[B]
>>> g.children(B)
[]
How you will keep track of the nodes in the graph. How you will keep track of which nodes are connected.
Each of the methods should be short.
6.01 Final Exam Spring 09 Dene this class and its methods.
class DirectedGraph: nodes = {} def hasNode(self,n): return n in self.nodes def addNode(self,n): if not self.hasNode(n): self.nodes[n] = {} def addEdge(self,n,c): self.addNode(n) self.addNode(c) if not (c in self.nodes[n]): self.nodes[n][c] = True def children(self,n): return self.nodes[n].keys()
Dene a class UnDirectedGraph which has all the same methods as DirectedGraph, except that addEdge, adds edges in both directions. Here is an example use:
>>> g = UnDirectedGraph()
>>> g.addEdge(A,B)
>>> g.children(A)
[B]
>>> g.children(B)
[A]
Dene this class. Use inheritance to avoid rewriting all of the methods.
class UnDirectedGraph(DirectedGraph): def addEdge(self,n,c): DirectedGraph.addEdge(self,n,c) DirectedGraph.addEdge(self,c,n)
10
4.1 GraphSM
Dene the GraphSM class. Dene all the methods and attributes that you need for the state ma chine to be used for a search, as shown in the example above. You do not need to dene a done method.
class GraphSM(SM): def __init__(self, graph, startNode, maxChildren): self.graph = graph self.startState = startNode self.MaxChildren = maxChildren self.legalInputs = range(maxChildren) def getNextValues(self, state, inp) c = self.graph.children(state) if inp<len(c): state = c[inp] return (state,state)
11
4.2 Search
For the graph dened by the code shown above:
Show the sequence of partial paths expanded by depth-rst search without DP from S to G. Assume children of a state are pushed on the agenda (visited) in reverse alphabetical order. There are more than enough slots.
step 1 2 3 4 5 6 7 8 9 10 11 12 The nal path is SBDFG. partial path expanded S SA SAC SACE SB SBC SBCE SBD SBDE SBDF
List in order the states that are visited by breadth-rst search without DP starting at S and going to G. If a state is visited more than once, include it each time it is visited.
SBADCCFEEEG
List in order the states that are visited by breadth-rst search with DP starting at S and going to G. If a state is visited more than once, include it each time it is visited.
SBADCFEG
12
Part a. Enter the difference equation that relates the input sequence x[n] and output sequence y[n] for this system.
Part b. Enter the pole(s) of this system in the box below. If there are multiple poles, separate them with commas. If there are no poles, enter none.
3
Y 1 + 3R z + 3
= = X 1 3R z3
H=
6.01 Final Exam Spring 09 Part c. Consider a generalization of the previous system with the following form.
13
XT
HS =
N (R) D(R)
YT
Write a Python function called YinYang that takes a single input parameter HS, which is a SystemFunction that represents HS , and returns a SystemFunction that represents HT = YT (R)/XT (R).
def YinYang(HS): return sf.SystemFunction(HS.denominator+HS.numerator,HS.denominator-HS.numerator)
Part d. Consider the following code, which builds on the YinYang function in part c.
def TwoYinYangs(K): g1 = sf.Gain(K) h1 = YinYang(sf.R()) h2 = YinYang(sf.R()) return sf.FeedbackSubtract(sf.Cascade(g1,sf.Cascade(h1,h2)))
Enter the system function that will be returned by TwoYinYangs(3) in the box below. Express your answer as a ratio of polynomials in R.
H(R) =
3 1 + 2R + R2 =
4 1 + R + R2
(1 R)2 + 3 (1 + R)2
3 (1 + R)2
14
Which value of K would give rise to the following unit sample response?
0.1
The unit sample response oscillates with little decay. Therefore, the magnitude of the dominant pole must be 1. The period is approximately 10. Therefore, the angle of the dominant pole must be approximately 2/10 0.628, which is close to the answer for K = 0.1.
15
Observations
When a specially-equipped car drives down the road of interest, we can measure its speed. Know ing the cars speed gives us information about the trafc on the road. The conditional probability distribution Pr(Speed | Trafc) is specied in the following table. Speed Trafc Low Med High <10 0 0.2 0.5 10-20 0.1 0.2 0.5 20-30 0.1 0.2 0 30-40 0.1 0.2 0 40-50 0.2 0.2 0 50-60 0.2 0 0 60-70 0.2 0 0 70-80
0.1
0
0
Part a. Imagine that our initial belief about the trafc is:
What would be our updated belief given that the single observation is Oo = 75? Pr(S0 = Low | O0 = 75) = 1 Pr(S0 = High | O0 = 75) = Pr(S0 = Med | O0 = 75) = 0 0
What would be our updated belief given that the single observation is Oo = 45? Pr(S0 = Low | O0 = 45) = 2/3 Pr(S0 = High | O0 = 45) = Pr(S0 = Med | O0 = 45) = 0 1/3
What would be our updated belief given that the single observation is Oo = 5? Pr(S0 = Low | O0 = 5) = 0 Pr(S0 = High | O0 = 5) = Pr(S0 = Med | O0 = 5) = 5/7 2/7
16
Transitions
Now, consider how the trafc state changes over time. Well think about the trafc system as having two possible inputs (actions), N, and A. Input It = N means that there has been no disturbance on that stretch of road on step t; input It = A means that there has been an accident on that stretch of road at step t. Depending on whether there has or has not been an accident, the transition probabilities differ. The conditional probability distribution Pr(St+1 | St , It = N) is given by:
Low 0.9 0.1 0 S_t+1 Med 0.1 0.8 0.1 High 0 0.1 0.9
S_t
S_t
Part b1. If we are certain that the trafc is low at time 0 (that is, Pr(S0 = Low) = 1), and there are no accidents for the next two steps (and we make no observations), what is our belief about the state of the trafc at time 2? Specify the following values:
0.9 0.9 + 0.1 0.1 = 0.82 0.9 0.1 + 0.1 0.8 = 0.17 0.1 0.1 = 0.01
Part b2. If we are certain that the trafc is low at time 0, and there are accidents for the next two steps (and we make no observations), what is our belief about the state of the trafc at time 2? Specify the following values:
0 0 1
17
O0 = 75, I0 = A, O1 = 75, I1 = N
possible? (yes/no): no If no, briey explain why (one sentence only).
If we see an accident in step 0 (I0 = A) then we cannot possibly observe a speed of 75 in step 1 (O1 = 75).
O0 = 75, I0 = A, O1 = 15, I1 = N
possible? (yes/no): yes If no, briey explain why (one sentence only).
O0 = 75, I0 = N, O1 = 15, I1 = N
possible? (yes/no): yes If no, briey explain why (one sentence only).
Grading: 6 points for part a; 4 points for part b; 4 points for part c.
18
Vi
VM
motor
pot
Vo
The error E between the input voltage Vi and output voltage Vo is multiplied by the gain K to generate the motor input voltage VM . Assume that the angular speed of the motor shaft (, not shown) is proportional to VM so that = KM VM . The motor turns the shaft of a potentiometer (pot) to angle and the output voltage from the potentiometer (Vo ) is proportional to the shaft angle, i.e., Vo = . We wish to make a model of this system in which the shaft angle at time n is equal to the shaft angle at time (n 1) plus the product of the time between steps, T , times the angular speed at time (n 1),
[n] = [n 1] + T [n 1]
where [n] is the nth sample of the signal and [n] is the nth sample of the signal. Part a. Draw a block diagram for the entire motor system that consists of just adders, gains, and delays. Label the nodes that correspond to Vi , Vo , E, VM , , and .
Vi
VM
KM
Vo
H=
Vo = Vi
KKM T R 1 R + KKM T R
19
Part c. The step response of the system was measured by stepping the input voltage from 0 V for times n < 0 to 1 V for times n 0. Based on this measurement, it was concluded that the system function can be written in the following form:
H=
1 R Vo =
4 3 Vi 1 4 R
Which of the following step responses is consistent with the previous equation?
VA 1 n VD 1 n VG 1 n 1 1 1
VB 1 n VE 1 n VH 1 n
VC
n VF
n VI
VF
1 3
y[n] = x[n 1] + y[n 1] 4 4
1 3
y[0] = x[1] + y[1] = 0 4 4
1 3 1
y[1] = x[0] + y[0] = 4 4 4
3 1 3 1 7
1 y[2] = x[1] + y[1] = + =
16
4 4 4 4 4 1 3 1 3 7 37
y[3] = x[2] + y[2] = + =
64 4 4 4 4 16
20
Part d. The motor control circuit was wired up to the robot so that the robots brain could command the motor input voltage Vi from the analogOutput and read the resulting motor output voltage Vo via an analogInput. motor controller
analogOutput
Vi
1 4R 3 1 4R
Vo
analogInput
The following code implements a brain that toggles the motor position back and forth by toggling the analogOutput between 0.3 V and 0.7 V.
class motorControlBrain(sm.SM): startState = 0 def getNextValues(self, state, inp): vo = inp.analogInput[0] # vo is the output voltage from the previous step newState = (state+1)%100 if newState>50: vx = 0.7
else:
vx = 0.3
return (newState,io.Action(voltage=vx))
A brilliant student gured out that it was possible to speed up the response of the motor controller by changing the control code without changing the hardware in any way! The student simply changed the last line of motorControlBrain to the following (leaving the other lines as they were):
return (newState,io.Action(voltage=C*vx-D*vo))
where C and D are constants. We will refer to the resulting system as the CD Motor Controller. Draw a block diagram that relates the input VX to the output Vo for the CD Motor Controller. Your block diagram should include the original motor controller, which is already provided below.
1R 4 3 1 4R
VX
Vi D
Vo
21
HX =
Vo = VX
1 4 CR
3 1 2 4 R +
4 DR
Vo HX = = C
VX 1 + D
1 4R 1 3 R 4 1 2 4R 1 3 R 4
1 4 CR
3 R +
1 DR2 4 4
Part f. To use the CD Motor Controller, our brilliant student had to determine values of the constants C and D. The values that were chosen gave rise to the following system function:
HX =
25
Vo 64 R
= .
3 9 VX 1 4 R + 64 R2
Is the performance of this system better or worse than that of the original motor controller in part c? Briey explain your reasoning. The new system has two poles at z = 3 , while the old system had one pole at z = 3 . Thus 8 4 the magnitude of dominant pole in the new system is only half as big as the magnitude of the dominant pole of the old system, and the new system will respond faster than the old one.
Grading: 2 points for each of parts a, b, and c; 3 points for each of parts d, e, and f.
22
worksheet
23
worksheet
For information about citing these materials or our Terms of Use, visit: http://ocw.mit.edu/terms.