Mandelbrot Section#
Download this notebook from GitHub (right-click to download).
Most examples work across multiple plotting backends, this example is also available for:
HoloViews demo that used to be showcased on the [holoviews.org
import numpy as np
import holoviews as hv
from holoviews import dim, opts
hv.extension('bokeh')
Load the data#
import io
try: from urllib2 import urlopen
except: from urllib.request import urlopen
raw = urlopen('http://assets.holoviews.org/data/mandelbrot.npy').read()
array = np.load(io.BytesIO(raw)).astype(np.float16)[::2,::2]
Plot#
dots = np.linspace(-0.45, 0.45, 19)
fractal = hv.Image(array)
# First example on the old holoviews.org homepage was:
# ((fractal * hv.HLine(y=0)).hist() + fractal.sample(y=0))
layouts = {y: (fractal * hv.Points(fractal.sample([(i,y) for i in dots])) +
fractal.sample(y=y) +
hv.operation.threshold(fractal, level=np.percentile(fractal.sample(y=y)['z'], 90)) +
hv.operation.contours(fractal, levels=[np.percentile(fractal.sample(y=y)['z'], 60)]))
for y in np.linspace(-0.3, 0.3, 21)}
layout = hv.HoloMap(layouts, kdims='Y').collate()
layout.opts(
opts.Contours(color='w', show_legend=False),
opts.Points(size=dim('z')*10)).cols(2)