Почему я не могу построить этот фрейм данных dask с помощью datashader (недостаточно значений для распаковки)? - PullRequest
2 голосов
/ 15 апреля 2019

Я бы хотел построить граф с большим количеством элементов с помощью datashader + holoviews, но я получаю сообщение об ошибке.
Что-то маленькое и воспроизводимое:

import holoviews as hv
import pandas as pd
import dask.dataframe as dd
from holoviews.operation.datashader import (
    datashade, aggregate, dynspread,
    bundle_graph, split_dataframe,  regrid
)
from holoviews.element.graphs import layout_nodes
from datashader.layout import forceatlas2_layout, random_layout

hv.extension('bokeh')

targets = [4, 4, 4, 4, 4]
sources = [3, 1, 2, 3, 4]
df = pd.DataFrame({'source': sources, 'target': targets})
edges_df = dd.from_pandas(df, npartitions=3)

graph = layout_nodes(hv.Graph(edges_df), layout=forceatlas2_layout)
forceatlas = bundle_graph(graph, split=False)
pad = dict(x=(-.5, 1.3), y=(-.5, 1.3))
datashade(forceatlas, width=800, height=800) * forceatlas.nodes.redim.range(**pad)

, что не удается с

ValueError: недостаточно значений для распаковки (ожидается 3, получено 0)
---> 17 graph = layout_nodes (hv.Graph (dge_df), layout = forceatlas2_layout)

Однако, установив targets = [1, 1, 1, 1, 1], я получаю сюжет.
С "неисправным" targets, если я использую random_layout вместо forceatlas2, я также получаю сюжет.

Я озадачен!Почему я получаю эту ошибку и как от нее избавиться?Я использую datashader 0.7.0.

1 Ответ

0 голосов
/ 16 апреля 2019

Попробуйте заменить проблемную строку на
graph = layout_nodes(hv.Graph(edges_df), layout=forceatlas2_layout, kwargs = {'id': 'index'})

Это должно позволить справиться с внутренними библиотеками.

...