Beast Mode to Calculate Gains in Values
Hello,
I'm trying to create a beast mode to calculate gains in values over time to be displayed on a single value summary card. We have both the values and their corresponding dates. We are trying to calculate the gain based on the difference between the lowest and highest value (given that the highest occurs after the lowest) in a date range.
For example:
Date Value
5/20 2.2
5/21 2.1
5/22 2.2
5/23 2.3
5/24 2.7
With this data, we would return a value of 0.6, because the difference between the highest value (2.7) and lowest value (2.1) is 0.6. The highest value also occured after the lowest value.
Because we are taking into account that the highest must occur after the lowest, we cannot do a simple max(value) - min(value) that would omit certain edge cases.
For example, if we filter our dates, here is a case where we do not see a gain over time:
Date Value
5/20 2.2
5/21 2.1
So having our beast mode as max(value) - min(value) would calculate 0.1, and our summary number card would incorrectly show this as a gain when in fact there wasn't, due to the values decreasing over time. We might want to report that there was no gain or -0.1 gain on our summary number card.
Date Value
5/20 2.2
5/21 2.1
5/22 2.2
In this last edge case, we will add another date to our range. Based on our definition, we do see a gain over time of 0.1 where the highest value occurs after our lowest value (from 5/21 to 5/22). So it should correctly display 0.1, but also take into account that this it needs to compare the highest value from the most recent date (5/22 as opposed to 5/21, which was in our last example), so that it can correctly report a gain.
Any hints on how to do this? Trying to sort this out ASAP, and would greatly appreciate the help!
Comments
-
I have one more question:
What output would you expect to see in this scenario:
Date Value
5/20 2.2
5/21 2.1
5/22 2.2
5/23 2.3
5/24 2.7
5/25 2.0
My assumption would be a null value? When there is no growth after the minimum value in a timeperiod, do you want an output of zero or null?
“There is a superhero in all of us, we just need the courage to put on the cape.” -Superman0 -
@ST_-Superman-_ wrote:I have one more question:
What output would you expect to see in this scenario:
Date Value
5/20 2.2
5/21 2.1
5/22 2.2
5/23 2.3
5/24 2.7
5/25 2.0
My assumption would be a null value? When there is no growth after the minimum value in a timeperiod, do you want an output of zero or null?
Scott - that is an excellent point to bring up! I brought this up when you posted this and am still waiting on internal confirmation of what I should expect to return for this edge case. I may repost when I have the answer, for visibility!
0
Categories
- All Categories
- 1.8K Product Ideas
- 1.8K Ideas Exchange
- 1.5K Connect
- 1.2K Connectors
- 300 Workbench
- 6 Cloud Amplifier
- 8 Federated
- 2.9K Transform
- 100 SQL DataFlows
- 616 Datasets
- 2.2K Magic ETL
- 3.9K Visualize
- 2.5K Charting
- 738 Beast Mode
- 56 App Studio
- 40 Variables
- 685 Automate
- 176 Apps
- 452 APIs & Domo Developer
- 47 Workflows
- 10 DomoAI
- 36 Predict
- 15 Jupyter Workspaces
- 21 R & Python Tiles
- 394 Distribute
- 113 Domo Everywhere
- 275 Scheduled Reports
- 6 Software Integrations
- 124 Manage
- 121 Governance & Security
- 8 Domo Community Gallery
- 38 Product Releases
- 10 Domo University
- 5.4K Community Forums
- 40 Getting Started
- 30 Community Member Introductions
- 108 Community Announcements
- 4.8K Archive