Skip to main content

Background

This use case shows how to create a custom visualization / chart that can be displayed on your DashHub dashboard as a tile. We can do this via MLHub. In this use case example, we will create a bar chart to track a key process metric at a facility, monthly average energy usage. Once we have added this visualization as a tile to the target dashboard, we can add other visualizations, as needed, following a similar procedure. These dashboards can then be shared with your peers.

 

Solution

The solution includes the following steps:

  1. Create a TrendHub view: Create a TrendHub view with all of the relevant tags. Adjust the time period on your focus chart. You will want to include all of the data that will be used to create your visualization. Save this TrendHub view.                                                                         
    TrendHub view with focus chart duration spanning the entire year of 2024.

     

  2. Create a new MLHub notebook: Navigate to MLHub and create a new notebook.
  3. Insert initialization script: On the left-hand side of the notebook, select the Initialization script located under “Snippets”. This will load the initialization code cell into the notebook.                        
    Initialization script snippet added to the notebook (I included plotly import statements because we will be needing that library to create our visualization).

     

  4. Load your saved TrendHub view: We will now bring in the TrendHub data into the notebook. To do this, select the blue plus button next to “TrendMiner Content”. The system will then prompt you to select the TrendHub view. Once the view is selected, the code to load the data and the view will be added to your notebook.                                                                                          

     

  5. Code the visualization using the data from the view: Now that we have our TrendHub data stored as a dataframe, we can create our visualization. I will be using Plotly to create a bar chart, which will display monthly average energy usage. In my code, I have a few data preprocessing steps - resampling the data to a monthly frequency since we want to show monthly statistics and converting the units - and formatting the chart - adjusting and labeling the y and x axes.                                                                                                                        
    Code to create Plotly bar chart.
    Plotly bar chart created from the code above.

     

  6. Dashboard Integration: In order to display this bar chart in our target dashboard, we first need to publish a pipeline. At the top right of the screen, select “Publish → New Pipeline”.    
    To display this chart in a dashboard, we first need to publish a pipeline.

    Select all of the code cells that we used to create the figure. In this example, this includes the initialization snippet, the TrendHub view loading snippet, and the figure creation code block. Once the pipeline has been created and saved, we can navigate to our dashboard in DashHub. In your target dashboard, create a new tile (make sure you are in Edit mode). Select “Notebook output” and then choose the Pipeline we just created. After clicking “Add new tile”, the figure should now be displayed as a tile - kudos!                                                       

    Custom visualization added to target dashboard.

     

With MLHub, the number of different visualizations you can add to your TrendMiner dashboards is virtually endless. I'm really curious to see which other visualizations our customers have created. If you have any, feel free to share below...


This is a super useful mini-tutorial. I just worked through an example with a co-op student combining this tutorial and a few other resources: 

A couple things I noticed that are missing or under-emphasized in the tutorial (I am lacking Jupyter experience so this might be intuitive to ML people): 

  • On our current version of Trendminer, pipelines can’t be published anywhere but the “root” user folder, even if a subfolder is selected. 
  • After clicking Publish, the select “All/None” is a bit hard to see but it’s in the top-right corner, and is not visible unless Publish has been clicked. 
  • If sharing a DashHub view that contains a graph output from MLHub, I believe the source TrendHub view, the DashHub view itself, AND the Pipeline need to be shared with “Everyone” (or the named users who should be able to view the output). 

Here is our example test visualization (sub-section of a DashHub view) using Plotly Express: 
 

 

Some of the neat (to us) realizations were how easy it is to filter data frames. This is the line immediately before the Plotly visualization: 

# filter dataframe 
tag_data_df = tag_data_df/tag_data_dff'xxxxxxxxxxxxxxxx-T-CTRLR.OP'] < 40]

And here is our Plotly call: 

fig = px.scatter(
tag_data_df,
y='xxxxxxxxxxxxxxxxxxxxx-T-CTRLR.OP',
x='xxxxxxxxxxxxxxxxxxxxx-MASS-F.PV',
color='xxxxxxxxxxxxxxxxxxxxxx-T.PV',
marginal_x="histogram",
marginal_y="histogram",
trendline="lowess"
)
fig.show()

 


Thank you for sharing, @brahmneufeld . Nice visualization and very useful feedback.

@Tim Haselaars @Christina Linne @Wouter Daniels FYI


One more piece of feedback from yesterday afternoon of pouring over the examples of Github: to a beginner who is trying to rapidly just test stuff and see what works, it’s not immediately clear which examples on Github are applicable to Custom Calcs and which are applicable to MLHub. 

Eduardo shared with me that the big hint is the .csv creation at the end of the script, as that is how data is deployed to custom tags:

Just sharing this for the benefit of others. 


Reply