Changing dimensions
The simplest of dimension-changing operations are aggregate and drill-down. These features basically mean that you either add or remove an additional dimension to/from an axis or another channel.
Let’s aggregate together the elements by getting the Genres
dimension off the
x-axis. By taking it off the chart, only one chart element remains for every
color, and ipyvizzu
automatically calculates and shows the aggregate value of
the elements.
Info - How to setup Chart
import pandas as pd
from ipyvizzu import Chart, Data, Config
data_frame = pd.read_csv(
"https://ipyvizzu.vizzuhq.com/0.15/assets/data/music_data.csv"
)
data = Data()
data.add_data_frame(data_frame)
chart = Chart()
chart.animate(data)
chart.animate(
Config(
{
"channels": {
"y": {"set": ["Popularity", "Kinds"]},
"x": {"set": ["Genres"]},
"label": {"attach": ["Popularity"]},
},
"color": {"attach": ["Kinds"]},
}
)
)
chart.animate(
Config(
{
"channels": {
"x": {"set": None},
}
}
)
)
When you simultaneously add and remove dimensions, the partitioning of the underlying data to markers on the chart changes. There are multiple ways to transition through these kinds of operations using.
By default, the markers are aggregated to the common base of the two states, then drilled down to the target state, as shown below.
chart.animate(
Config(
{
"channels": {
"y": {
"detach": ["Kinds"],
},
"x": {
"set": ["Genres"],
},
"color": {
"set": None,
},
}
}
)
)
You can change this setting and drill down to the union of the two states instead, and then aggregate to the target state:
chart.animate(
Config(
{
"channels": {
"x": {
"detach": ["Genres"],
"attach": ["Kinds"],
},
}
}
),
regroupStrategy="drilldown",
)
There is also the option to fade the chart between the states:
chart.animate(
Config(
{
"channels": {
"x": {
"detach": ["Kinds"],
"attach": ["Genres"],
},
}
}
),
regroupStrategy="fade",
)
To simply drill down, the same dimension is put back on the y-axis.
chart.animate(
Config(
{
"channels": {
"y": {
"attach": ["Kinds"],
},
"color": {
"set": ["Kinds"],
},
}
}
)
)