In my previous blog post, I created a simple, 3-step process for ingesting streaming data and performing face recognition live. I pointed my webcam at the Avengers: Endgame movie to show how my face recognition script identified each of the main characters and assessed the relationships among them. Now, as promised, I'll dive more deeply into how we can play with this data in the Deephaven IDE. I focus primarily on real-time plotting, creating a set of charts that update as my data streams in.
As a refresher, here is the table and three graphs I produced in the first blog:
First appearance
This table records the first appearance of each main character in real time. One line of code creats the table, then I reversed the table so that new rows are appended to the top of the table for better visualization. (Tip: you can also do this in the UI by right-clicking the table data and selecting Reverse.) Doing this programmatically is simple:
attendance=attendance_table.select(formulas=["KafkaTimestamp","name"])
attendance=attendance.reverse()
Leading characters
This graph compares the total appearance times of all the main characters. We simply count the total appearance of each character and plot a histogram to demonstrate how this count changes as the movie plays. It's straightforward to do table operations such as count and sort in Deephaven. And by simply passing the table to figure creates a dynamic plot.
Here's the code:
leading_act=re.count_by("Count",by=["name"]).sort_descending(order_by=["Count"])
figure = Figure()
new_f = figure.plot_cat(series_name="leading actor", t=leading_act, category="name", y="Count")
new_f = new_f.chart_title(title="Top leading character")
leading_actors = new_f.show()
First appearance of each character
This graph shows the minute at which each main character in the movie shows up. We first group the data by minutes, then count number of minute each character shows up. This gives us a rough estimate on how long each character appears on the screen. As the code shows, grouping based on time is easy in Deephaven with just a single line of code. Feel free to try 5 or 10 second intervals to see if you can get more accurate results.
The code:
re=relation_table.update_view(["TimeBin=upperBin(KafkaTimestamp,'00:01:00')"])
mins_table=re.select_distinct(formulas=["TimeBin","name"]).count_by("Count",by=["name"])
figure = Figure()
new_f = figure.plot_cat(series_name="roles showup in number of min", t=mins_table, category="name", y="Count")
new_f = new_f.chart_title(title="Show-up times of each character")
showup_mins_plot = new_f.show()
Dynamic duos
The graph tracks which characters appear together more often than the others. Here, I'm basically tracking relationships between characters.
After grouping the data by minutes, we pair all the characters in each minute, then count how many minutes they show up together. It helps us understand which two characters appear together more often than others. You can also try to group the data by 30 or 40 seconds to see if the relationship still holds.
The code:
re=relation_table.update_view(["TimeBin=upperBin(KafkaTimestamp,'00:01:00')"])
new_table=re.select_distinct(formulas=["TimeBin","name"])
new_table=new_table.count_by("Count",by=["TimeBin","name"])
new_table1=new_table.sort(["TimeBin","name"]).group_by("TimeBin").update(["sum=sum(Count)"]).where(["sum>1"]).select(["name"])
def make_pairs(*a):
l = []
for x in range(len(a)):
for y in range(x+1,len(a)):
l.append(a[x] + "-" + a[y])
return array(string, l)
t3 = new_table1.update("Pair=(String[])make_pairs(name)").drop_columns("name").ungroup()
figure = Figure()
new_fig = figure.plot_cat_hist(series_name="Keys count", t=t3, category="Pair")
new_fig = new_fig.chart_title(title="Number of times each pair of character hanging out")
relationships_plot = new_fig.show()
Try it out
Please check out our deephaven-examples repo on GitHub to see detailed documentation on how we accomplish the analysis or contact us on Slack if you have any questions or feedback.