A document from MCS 275 Spring 2022, instructor Emily Dumas. You can also get the notebook file.

MCS 275 Spring 2022 Homework 11

  • Course Instructor: Emily Dumas

Instructions:

  • Complete the problems below, which ask you to write Python scripts.
  • Upload your python code directly to gradescope, i.e. upload the .py files containing your work. (If you upload a screenshot or other file format, you won't get credit.)

Deadline

This homework assignment must be submitted in Gradescope by Noon central time on Tuesday 5 April 2022.

Collaboration

Collaboration is prohibited, and you may only access resources (books, online, etc.) listed below.

Resources you may consult

These things might be helpful while working on the problems. Remember that for worksheets, we don't strictly limit what resources you can consult, so these are only suggestions.

Point distribution

This homework assignment has one problem. The grading breakdown is:

Points Item
2 Autograder
4 Problem 2
6 Total

The part marked "autograder" reflects points assigned to your submission based on some simple automated checks for Python syntax, etc.. The result of these checks is shown immediately after you submit.

What to do if you're stuck

Ask your instructor or TA a question by email, in office hours, or on discord.

No problem 1 as usual

Problem 2: Computer room cooling capacity

This problem is about the temperature in a room full of computers used for scientific calculations. The room is cooled by an air conditioning (A/C) unit. Imagine you suspect the A/C has insufficient capacity for the room, but only when the computers have sustained high utilization and the outside air temperature is very high (e.g. mid-summer). In general, computers emit more heat when the CPU utilization is high.

Use matplotlib to make a visualization of the computer room air temperature and the outside air temperature on the same set of axes. This is the sort of graph you might use to investigate your suspicions about cooling capacity.

The data you need for this is available in two files:

  • roomtemp.csv

    • It has two columns: timestamp (the time in seconds since midnight on 1 January 1970 GMT) and temp which holds the room temperature in Fahrenheit. This file is large, because measurements are taken every minute.
  • weather.csv

    • It has two columns: timestamp (as above) and temp which holds the outside air temperature. This file is small, because the air temperature is only recorded once per hour.

Your script should be called hwk11.py, and should make a plot with the following characteristics:

  • The data from both CSV files is shown, one line for each file
  • A blue line shows the computer room temperature
  • A red line shows the outside air temperature
  • The x axis has no label, and remains in units of seconds since 1 Jan 1970 GMT
  • The y axis is labeled "temp (F)"
  • The plot is titled "Computer room and outside air temps"
  • The plot has a legend which refers to the lines as "room" and "outside".

Here's a hand sketch showing the overall design of the intended plot. It doesn't show the actual data.

Sketch of the plot design

Then, once you've seen the actual plot, answer these questions in comments in your file:

  • Do you see any sign that the room temperature sensor might be malfunctioning? If so, where?
  • Do you think this plot can be used to draw a conclusion about the original question---whether the room has enough A/C capacity? If not, what more information would you want?

Hints

  1. You don't need to do anything special to make two plots appear on the same axes. If you simply call plt.plot() twice, that's what will happen.
  2. The regularl oscillations in outside tempearture seen in the plot are days! (The x axis units might obscure this fact, but the plot shows about two weeks of data.)