Over a million developers have joined DZone.

Creating a Heat Map of Ratios With Seaborn

DZone's Guide to

Creating a Heat Map of Ratios With Seaborn

See how to create a heat map containing the ratio of males to females in the population by age for 1970 to 2015 with Seaborn.

· Big Data Zone
Free Resource

See how the beta release of Kubernetes on DC/OS 1.10 delivers the most robust platform for building & operating data-intensive, containerized apps. Register now for tech preview.

In this post, we will see how to create a heat map with Seaborn. We'll use a dataset from the Wittgenstein Centre Data Explorer. The data extracted is also reported here in CSV format. It contains the ratio of males to females in the population by age for 1970 to 2015 (data reported after this period is projected). First, we import the data using Pandas:

import pandas as pd
import numpy as np

sex_ratios = pd.read_csv('m2f_ratios.csv', skiprows=8)

age_code = {a: i for i,a in enumerate(sex_ratios.Age.unique())}
age_label = {i: a for i,a in enumerate(sex_ratios.Age.unique())}
sex_ratios['AgeCode'] = sex_ratios.Age.apply(lambda x: age_code[x])

area_idx = sex_ratios.Area == \
           'United Kingdom of Great Britain and Northern Ireland'
years_idx = sex_ratios.Year <= 2015
sex_ratios_uk = sex_ratios[np.logical_and(years_idx, area_idx)]

Here, take care of the age coding and isolate the data for the United Kingdom and Northern Ireland. Now, we can rearrange the data to see ratio per year and age using a pivot table, we can then visualize the result using the heatmap function in Seaborn:

import seaborn as sns

pivot_uk = sex_ratios_uk.pivot_table(values='Ratio', 
pivot_uk.index = [age_label[a] for a in pivot_uk.index.values]

plt.figure(figsize=(10, 8))
plt.title('Sex ratio per year and age groups')
sns.heatmap(pivot_uk, annot=True)

In each year, we see that the ratio was above 1 (in favor of males) for young ages. It then becomes lower than 1 during adulthood and keeps lowering with age. It also seems that with time, the ratio decreases more slowly. For example, we see that the age group 70-74 had a ratio of 0.63 in 1970, while the ratio in 2015 was 0.9.

New Mesosphere DC/OS 1.10: Production-proven reliability, security & scalability for fast-data, modern apps. Register now for a live demo.

big data ,data visualization ,tutorial ,seaborn

Published at DZone with permission of Giuseppe Vettigli, DZone MVB. See the original article here.

Opinions expressed by DZone contributors are their own.

{{ parent.title || parent.header.title}}

{{ parent.tldr }}

{{ parent.urlSource.name }}