Загрузка не удалась. Возможно, проблемы с правами доступа?

Внешний вид графиков

В matplotlib можно изменять не только тип самого графика (линия или столбцы), но и регулировать внешний вид выбранного типа:

import matplotlib.pyplot as plt
import numpy as np
 
 
x_axis = range(1, 20)
y_axis = [i * i for i in range(1, 20)]
 
lines = plt.plot(x_axis, y_axis) # здесь начинается отличие от примера из предыдущей недели. Мы сохраняем результат выполнения метода plot в отдельную переменную
 
plt.setp(lines, color='red', linewidth=2.0) # теперь, с помощью метода setp мы можем изменять форму линии. 
                                            # В данном случае, цвет устанавливаем в красный, а ширину линии делаем равной 2-м
 
plt.show()

Возможные параметры

Параметр Значения Смысл
alpha 0.0 ⇐ x ⇐1.0 прозрачность
antialiased True, False сглаживать или нет
color red, blue, black и т.д. цвет
linestyle '-', '–', '-.', ':', 'steps', … вид линии
linewidth вещественное число ширина линии
marker '+', ',', '.', '1', '2', '3', '4' вид меток
markeredgecolor red, blue, black и т.д. цвет границы меток
markeredgewidth вещественное число ширина границы меток
markerfacecolor red, blue, black и т.д. цвет внутренней части меток
markersize вещественное число размер меток

Размещение нескольких графиков

На одном рисунке можно разместить несколько графиков. Делается это с помощью метода add_subplot(r, c, num). Что означают аргументы: add_subplot делит область рисования на прямоугольную сетку размером $r\times c$, где $r$ это количество рядов, а $c$ - количество столбцов. $num$ это номер графика в сетке, нумерация идет с левого верхнего угла, слева направо и начинается с единицы. В качестве результата, add_subplot возвращает специальную структуру данных, которая представляет собой описание осей.

Рассмотрим так же описание рисунка, которое делается с помощью метода figure. Неявно описание рисунка и добавление графика присутствует всегда, просто если мы никак в коде программы не обращаемся к методам figure и sub_plot, то библиотека подставляет значение по-умолчанию: figure(1) и add_subplot(1, 1, 1)

Посмотрим на пример:

import matplotlib.pyplot as plt
import numpy as np
 
 
def f(t):
    return np.exp(-t) * np.cos(2*np.pi*t)
 
t1 = np.arange(0.0, 5.0, 0.1)
t2 = np.arange(0.0, 5.0, 0.02)
 
fig = plt.figure(num=None, figsize=(8, 6), dpi=96, facecolor='w', edgecolor='k') # опишем явно рисунок. Без номера, размером 8 на 6 дюймов и разрешением
# 96 точек на дюйм. Цвет фона будет белый, а цвет контура - черный
ax1 = fig.add_subplot(2, 1, 1) # добавим первый график и его "оси" сохраним в структуре ax1. Будет создана сетка размером 2 ряда на 1 столбец в первую ячейку которой и будет помещен график
line1 = ax1.plot(t2, f(t2)) # нарисуем в нужных осях первый график
plt.setp(line1, color='blue', alpha=0.75)
ax2 = fig.add_subplot(2, 1, 1) # добавим еще один график туда же
marker_line = ax2.plot(t1, f(t1)) # и нарисуем линию меток
plt.setp(marker_line, marker='o', color='blue', linestyle='') # вот такого вида
 
 
ax3 = fig.add_subplot(2, 1, 2)
line2 = ax3.plot(t2, np.cos(2*np.pi*t2))
plt.setp(line2, color='green', linestyle='--')
 
plt.show()

Подписи к графикам

Чтобы разобраться с подписями к данным и получить некоторые математические знания, нарисуем диаграмму распределения случайных чисел

import matplotlib.pyplot as plt
import numpy as np
 
mu, sigma = 100, 15 # зададим значения среднего и разброса
x = mu + sigma * np.random.randn(10000) # новая функция для генерации случайных чисел: в качестве аргумента принимает требуемое количество случайных чисел,
# а возвращает список из вещесвенных значений случайных чисел. Обратите внимание, что x в результате тоже будет списком из 10 тыс элементов, каждый из которых
# представляет собой случайное число, умноженное на sigma и сдвинутое на mu
 
fig = plt.figure(num=None, figsize=(8, 6), dpi=96, facecolor='w', edgecolor='k')
 
ax1 = fig.add_subplot(1, 1, 1)
# the histogram of the data
ax1.hist(x, 50, normed=1, facecolor='g', alpha=0.75) # новая форма гистограммы, в виде равномерного массива значений
 
 
ax1.set_xlabel('Значения') # подпись для оси Х
ax1.set_ylabel('Вероятность') # подпись для оси Y
ax1.set_title('Гистограмма распределения') # заголовок диаграммы
ax1.text(60, .025, r'$\mu=100,\ \sigma=15$') # текст, добавленный в окрестности точки (60; 0,025). Значения задаются в координатах графика, а не пикселей на экране
ax1.axis([40, 160, 0, 0.03]) # метод axis позволяет описать диапазоны значений для осей. В данном случае, на оси Х будут отображены значения от 40 до 160,
# а на оси Y от 0 до 0,03
ax1.grid(True) # показывать ли координатную сетку
plt.show()

Задание 15

Нарисовать в окне на двух разных графиках 10 стран с наибольшим количеством регионов и наибольшим количеством городов. Оси графиков подписать.

Задание 16

Пусть есть некоторая окружность радиуса $r$, которая катится горизонтально и без проскальзываний. Возьмем точку $M$, находящуюся на расстоянии $h$ от центра окружности. При движении окружности, точка будет описывать некоторую кривую. Параметрически ее можно задать следующими уравнениями: $x=rt-h\sin{t}$, $y=r-h\cos{t}$. Кривые такого вида называются трохоидами. Задача: нарисовать на одном рисунке три отдельных диаграммы с траекториями движения точки $М$ при $h>r$, $h<r$, $h=r$

Задание 17

Фигуры Лиссажу описываются двумя уравнениями.

$$\begin{array} [b]{l} x(t)&=A \sin(at+d)\\ y(t)&=B \sin(bt) \end{array} $$

$x(t)$ и $y(t)$ представляют собой гармонические колебания в перпендикулярных плоскостях, которые зависят от частот $a$ и $b$, а так же от фазы $d$. Если $A=B$ и $d=\frac{\pi}{2}$, то фигурой Лиссажу будет окружность. Если $b/a=2$ и $d=\frac{\pi}{2}$ - парабола. Задача: рассмотреть виды фигур Лиссажу при разных значениях параметров.