Filtro para Gráfico de Pizza Matplotlib

Beginner

This tutorial is from open-source community. Access the source code

Introdução

Neste laboratório, demonstraremos como usar efeitos de filtragem com o gráfico de pizza do Matplotlib. Usaremos o código de desenho do gráfico de pizza emprestado de pie_demo.py e adicionaremos efeitos de filtragem ao gráfico. Os efeitos de filtragem são eficazes apenas se o seu renderizador SVG os suportar.

Dicas para a VM

Após a inicialização da VM, clique no canto superior esquerdo para mudar para a aba Notebook e acessar o Jupyter Notebook para praticar.

Às vezes, pode ser necessário aguardar alguns segundos para que o Jupyter Notebook termine de carregar. A validação das operações não pode ser automatizada devido a limitações no Jupyter Notebook.

Se você enfrentar problemas durante o aprendizado, sinta-se à vontade para perguntar ao Labby. Forneça feedback após a sessão, e resolveremos o problema prontamente para você.

Criar um Gráfico de Pizza

Criaremos uma figura e eixos quadrados para o nosso gráfico de pizza. Definiremos os rótulos e fracs para o gráfico. Também definiremos os valores de explode para as fatias do gráfico. Finalmente, desenharemos o gráfico de pizza com os parâmetros definidos.

import matplotlib.pyplot as plt
from matplotlib.patches import Shadow

fig = plt.figure(figsize=(6, 6))
ax = fig.add_axes([0.1, 0.1, 0.8, 0.8])

labels = 'Frogs', 'Hogs', 'Dogs', 'Logs'
fracs = [15, 30, 45, 10]
explode = (0, 0.05, 0, 0)

pies = ax.pie(fracs, explode=explode, labels=labels, autopct='%1.1f%%')

for w in pies[0]:
    w.set_gid(w.get_label())
    w.set_edgecolor("none")

for w in pies[0]:
    s = Shadow(w, -0.01, -0.01)
    s.set_gid(w.get_gid() + "_shadow")
    s.set_zorder(w.get_zorder() - 0.1)
    ax.add_patch(s)

plt.show()

Salvar o Gráfico como SVG

Salvaremos o gráfico de pizza como um arquivo SVG usando os módulos io e xml.etree.ElementTree. Definiremos a definição do filtro para a sombra usando um desfoque gaussiano e um efeito de iluminação. O filtro de iluminação é copiado de http://www.w3.org/TR/SVG/filters.html. Testaremos o filtro usando Inkscape e Firefox3, mas observe que a exportação do Inkscape pode não suportá-lo.

import io
import xml.etree.ElementTree as ET

f = io.BytesIO()
plt.savefig(f, format="svg")

filter_def = """
  <defs xmlns='http://www.w3.org/2000/svg'
        xmlns:xlink='http://www.w3.org/1999/xlink'>
    <filter id='dropshadow' height='1.2' width='1.2'>
      <feGaussianBlur result='blur' stdDeviation='2'/>
    </filter>

    <filter id='MyFilter' filterUnits='objectBoundingBox'
            x='0' y='0' width='1' height='1'>
      <feGaussianBlur in='SourceAlpha' stdDeviation='4%' result='blur'/>
      <feOffset in='blur' dx='4%' dy='4%' result='offsetBlur'/>
      <feSpecularLighting in='blur' surfaceScale='5' specularConstant='.75'
           specularExponent='20' lighting-color='#bbbbbb' result='specOut'>
        <fePointLight x='-5000%' y='-10000%' z='20000%'/>
      </feSpecularLighting>
      <feComposite in='specOut' in2='SourceAlpha'
                   operator='in' result='specOut'/>
      <feComposite in='SourceGraphic' in2='specOut' operator='arithmetic'
    k1='0' k2='1' k3='1' k4='0'/>
    </filter>
  </defs>
"""

tree, xmlid = ET.XMLID(f.getvalue())
tree.insert(0, ET.XML(filter_def))

for i, pie_name in enumerate(labels):
    pie = xmlid[pie_name]
    pie.set("filter", 'url(#MyFilter)')

    shadow = xmlid[pie_name + "_shadow"]
    shadow.set("filter", 'url(#dropshadow)')

fn = "svg_filter_pie.svg"
print(f"Saving '{fn}'")
ET.ElementTree(tree).write(fn)

Visualizar o Gráfico de Pizza com Efeitos de Filtragem

Visualizaremos o gráfico de pizza com os efeitos de filtragem aplicados. Usaremos o Inkscape para abrir o arquivo SVG e visualizar o gráfico de pizza com os efeitos de filtragem.

Modificar o Gráfico de Pizza com Diferentes Filtros

Podemos modificar o gráfico de pizza com diferentes filtros alterando a definição do filtro. Podemos experimentar com diferentes filtros para obter diferentes efeitos visuais.

filter_def = """
  <defs xmlns='http://www.w3.org/2000/svg'
        xmlns:xlink='http://www.w3.org/1999/xlink'>
    <filter id='dropshadow' height='1.2' width='1.2'>
      <feGaussianBlur result='blur' stdDeviation='2'/>
    </filter>

    <filter id='MyFilter2' filterUnits='objectBoundingBox'
            x='0' y='0' width='1' height='1'>
      <feGaussianBlur in='SourceAlpha' stdDeviation='4%' result='blur'/>
      <feOffset in='blur' dx='4%' dy='4%' result='offsetBlur'/>
      <feSpecularLighting in='blur' surfaceScale='5' specularConstant='.75'
           specularExponent='20' lighting-color='#bbbbbb' result='specOut'>
        <fePointLight x='50%' y='50%' z='5000%'/>
      </feSpecularLighting>
      <feComposite in='specOut' in2='SourceAlpha'
                   operator='in' result='specOut'/>
      <feComposite in='SourceGraphic' in2='specOut' operator='arithmetic'
    k1='0' k2='1' k3='1' k4='0'/>
    </filter>
  </defs>
"""

tree, xmlid = ET.XMLID(f.getvalue())
tree.insert(0, ET.XML(filter_def))

for i, pie_name in enumerate(labels):
    pie = xmlid[pie_name]
    pie.set("filter", 'url(#MyFilter2)')

    shadow = xmlid[pie_name + "_shadow"]
    shadow.set("filter", 'url(#dropshadow)')

fn = "svg_filter_pie2.svg"
print(f"Saving '{fn}'")
ET.ElementTree(tree).write(fn)

Resumo

Neste laboratório, aprendemos como usar efeitos de filtragem com o gráfico de pizza do Matplotlib. Criamos um gráfico de pizza, salvamos como um arquivo SVG e aplicamos efeitos de filtragem ao gráfico. Também modificamos o gráfico de pizza com diferentes filtros para obter diferentes efeitos visuais.