Home / Week 3 Exercises / System Functionals in Python

System Functionals in Python

The questions below are due on Sunday February 24, 2019; 11:00:00 PM.
 
You are not logged in.

If you are a current student, please Log In for full access to this page.
A Python Error Occurred:

Error on line 35 of Python tag (line 36 of source):
    from lib601.sf import SystemFunctional

ModuleNotFoundError: No module named 'lib601'

Music for this Problem
Goals In this exercise, we will develop a Python representation for system functionals and add it to our modular representation from earlier exercises. This addition will be useful for analyzing the performance of systems.

1) System Functionals in Python

System Functionals are rational polynomials in {\cal R} (the right-shift operator). As such, when thinking about implementing system functionals, it will be useful to have a nice representation for polynomials in Python. In previous exercises, we have used lists of coefficients to represent polynomials. However, from here moving forward, we will use a class called Polynomial instead (so that it is always clear what that we are dealing with polynomials, rather than arbitrary lists).

Polynomial instances will be initialized with a single argument (a list of coefficients in the form we have seen in the past). They will provide mostly the same operations you implemented in last week's Polynomial exercise, but through a slightly different interface (see the documentation for more information)

We will represent system functionals as ratios of polynomials that are described as instances of this Polynomial class. Thus, we will represent the polynomial 3\mathcal{R}^2+4\mathcal{R}+17 as

poly1 = Polynomial([17, 4, 3])
and the polynomial z^4+4z as
poly2 = Polynomial([0, 4, 0, 0, 1])

Check Yourself 1:

Create an instance of Polynomial called poly3 to represent the denominator of the system functional {3\mathcal{R}+2\over 6\mathcal{R}^2+5\mathcal{R}+1}.

Create an instance called poly4 to represent the denominator of the corresponding system function {3z+2z^2\over 6+5z+z^2}.

poly3 =?

poly4 =?

What's the relation between the coefficients of `poly3` and `poly4`?

2) Implementation

System Functionals are a very useful representation for systems, and so we will use this exercise to build on the System class from an earlier exercise, expanding it to include a representation for system functionals, as well as some methods for manipulating systems in system functional form.

You should use the `lti.py` file from before as your starting point (you may want to save a copy of that file under a different name so that you have a backup in case something goes wrong).

Because we will be dealing with polynomial math, you should import our implementation of the Polynomial class into your lti.py file by adding the following at the beginning of the file:

from lib601.poly import Polynomial

2.1) Including System Functional

We will start by making sure each instance of a System subclass includes within it a representation for that system's system functional. We will do this by adding two attributes to each subclass of System:

  • numerator should contain the numerator of the system functional (as a Polynomial in {\cal R}), represented as an instance of the Polynomial class from last week's exercises.
  • denominator should contain the denominator of the system functional, in the same form.

Modify the __init__ method for each of the system subclasses (R, Gain, FeedforwardAdd, Cascade, FeedbackAdd) so that it stores these two attributes, in addition to any other attributes it was storing before.

_Hint_: You may find your work from the previous two problems helpful!

2.2) Additional Operations

Since we can now rely on instances of all subclasses having numerator and denominator attributes representing the system functional, we can implement a few helpful methods that rely on this information. Augment the base System class by adding the following methods:

  1. poles(self): returns a list of the poles of the system.
  2. dominant_pole(self): returns one of the poles with greatest magnitude. If two or more poles have the same greatest magnitude, then any of these poles may be returned. If the system has no poles, the method should return None.
As with the polynomial operations from last week, we will not show you exactly the code we are using to test your implementation.

Note that if you are looking for ways to test your code, you should use it to find the poles (and dominant pole) of some systems of your own construction, or of the systems from the other exercises in this problem set (which you can solve by hand so you'll know what to expect!).

Submit your code for all of these changes by uploading your updated lti.py file below:

A Python Error Occurred:

  File "<CATSOOP ROOT>/language.py", line 133, in xml_pre_handle
    exec(code, e)
  File "<string>", line 204, in <module>
  File "<string>", line 204, in <listcomp>
NameError: name 'check_sf' is not defined

3) Mystery System

Use your Python framework to determine the poles of the following system.

Enter the poles you found for the mystery system, as a Python list of (possibly complex) numbers: