Source code for multiline_plot_example

import os
import json
import pandas as pd
from mdvtools.mdvproject import MDVProject
from mdvtools.charts.multi_line_plot import MultiLinePlot

[docs] def create_multi_line_plot(title, params, size, position, bandwith, intervals, scale, legend_display, legend_position, xaxis_properties, yaxis_properties): """Create and configure a MultiLinePlot instance with the given parameters.""" plot = MultiLinePlot( title=title, params=params, size=size, position=position ) plot.set_color_legend(legend_display, legend_position) plot.set_axis_properties("x", xaxis_properties) plot.set_axis_properties("y", yaxis_properties) plot.set_bandwidth(bandwith) plot.set_intervals(intervals) plot.set_scaletrim(scale) return plot
[docs] def load_data(path): """Load data from the specified CSV file.""" return pd.read_csv(path, low_memory=False)
[docs] def convert_plot_to_json(plot): """Convert plot data to JSON format.""" return json.loads(json.dumps(plot.plot_data, indent=2).replace("\\\\", ""))
[docs] def main(): """Main function to create the project and serve it.""" # Constants project_path = os.path.expanduser('~/mdv/project') data_path = "path_to_data" view_name = "default" # Create project project = MDVProject(project_path, delete_existing=True) # Load data data_frame = load_data(data_path) # Set the correct data type to the "leiden" data source (imports as integer but it should be str to appear as a category) data_frame['leiden'] = data_frame['leiden'].apply(str) # Add datasource project.add_datasource(data_path, data_frame) # MultiLinePlot parameters title = "MultiLine Plot Example" params = ["n_genes_by_counts", "leiden"] size = [792, 472] position = [10, 10] bandwith = 0.1 intervals = 40 scale = "0.001" legend_display = True legend_position = [375,1] xaxis_properties = {"label": "n_genes_by_counts", "textSize": 13, "tickfont": 10 } yaxis_properties = {"label": "density", "textSize": 13, "tickfont": 10 } # Create plot multi_line_plot = create_multi_line_plot(title, params, size, position, bandwith, intervals, scale, legend_display, legend_position, xaxis_properties, yaxis_properties) # Convert plot to JSON and set view multi_line_plot_json = convert_plot_to_json(multi_line_plot) multilineplot_view = {'initialCharts': {data_path: [multi_line_plot_json]}} project.set_view(view_name, multilineplot_view) project.set_editable(True) project.serve()
if __name__ == "__main__": main()