Using Flume to monitor flow rate

Hello,

Since it looks like Rachio/Flume are not interested in integration based on community and web search, I am looking for a way to integrate these in a more simple way. The issue perhaps you can help me solve is how to convert the inches per hour to gallons per hour. I would run my particular zone, look at how many gallons were used over a period of time and convert to GPH. I know its not exact but I find putting out tuna can method (actually I used orbit catch cups) not very accurate.

Any ideas?

You should learn how to use webhooks to get data from Rachio pushed to your rapberry pi or a server.
Should you need help with this, ask; otherwise all of the info you should need is here (link). If you don’t want to bother with port forwarding, you can use a http tunnel, such as localtunnel (link) to route data to your pi / local computer without port forwarding / DDNS.

This would send you a notifications with data about when a zone starts & when it ends. For the ending it also includes duration in seconds. You can either take a Flume reading at the start & another at the end, otherwise you could lookup history over the last timeframe outlined by duration. Lets assume you’ve gotten a start and end readings.

End reading - Start reading = Consumption
(optional, if your consumption is not in gallons): Convert Consumption to Gallons
Duration (from Rachio) / 3600 (seconds per hour) = x.yz (fraction of an hour that the zone has run).
(Consumption in Gallons) / (fraction of an hour) = Gallons / hour

You can even take continuous readings of your Flume data while the zone is running and calculate the duration that the zone has been active using an internal clock. This would allow you to detect and deactivate irrigation in case of an abnormal reading.

Should you be taking continuous readings, or have access to a high-resolution history data, than it would be a good idea to take a minimum reading you’ve read and estimate your GPH using that reading. Zone usage tends to be relatively stable, and any increase over min is likely someone else using the water in the house (better yet, schedule your irrigation while everyone is sleeping).

Good luck, we are here to help in case you run into issues.

1 Like

Thanks,

I have Home Assistant running on a Pi with the Flume and Rachio integrations. I’m an IT guy so I get what you are saying here. I think with the HA integrations I don’t have to deal with opening up ports and webhooks because the info is in HA and I can create an automation with Python or use the Node red integration I use for everything.

Great – new project!

Regards

1 Like

The conversion from gallons to inches will also still be inexact, as it depends on having non-overlapping zones, and measuring the square footage the zone covers, which is rarely rectangular. Next, convert gallons to cubic inches, and square feet into square inches, dividing to get inches, and then factoring time into it.

I have overlapping zones, and overlapping zones don’t coincide, as zone 1 covers part of zone 2, and zone 2 overlaps with zone 3. This obviously causes problems in calculating inches per hour for any particular zone, unless the zone (with circular areas) is properly mapped. The system really needs some significant rework to be properly zoned and code compliant to avoid watering the sidewalks.

@Frankge ,

For me Home Assistant didn’t give me access to the zone running information, so I finally broke down and did a short script that pulls data from the Rachio and Flume APIs and overlays Flume usage with Zone information. Since my sprinkler cycles run late at night and early AM, there’s no other water flow activity so this approach works. See the chart below. My Flume also picked up a slow leak in my sprinkler line that started a couple days ago, and I fixed yesterday - that’s the 0.09 gpm flow baseline when my sprinkling is off.

Can share how I did it if you want.

I am very interested in how you did this

1 Like

Hi @mitchican,

Two phases to setting it up:

  1. Learn how to use both the Rachio and the Flume REST API - web based APIs for pulling data. The toughest part is figuring out the login/authentication for each. Both use somewhat different protocols. Each has a description of how to authorize use their API on their site.
  2. Create a small program to collect the data, reformat and join the data by time (below in R). The pieces enclosed in <>'s are the auth tokens and codes developed from 1). Flume only allows a user to pull a single day of data at a time, so I have limited program to pull only a single day.
library(tidyverse)
library(jsonlite)
library(curl)
library(httr)

# Set up data pull window
Start_text <- "2024-07-07 00:00:00"
End_text <- "2024-07-08 00:00:00"

#Auto conversions to POSIXct and epoch_milliseconds representations for the APIs
Start = as.POSIXct(Start_text)
End = as.POSIXct(End_text)
Start_epoch <- paste0(as.integer(Start) * 1000)
End_epoch <- paste0(as.integer(End) * 1000)

# Pull event history from Rachio
h <- new_handle(verbose = TRUE)
handle_setheaders(h,
 "Content-Type" = "application/json",
 "Authorization" = "Bearer <secret code>")

request <- paste0("https://api.rach.io/1/public/device/<deviceid>/event?startTime=", Start_epoch, "&endTime=", End_epoch)
con <- curl(request, handle = h)

# Format and filter Rachio history to just watering starts and last end
watering <- prettify(readLines(con)) %>% 
  fromJSON() %>%
  mutate(eventDate = as.POSIXct(eventDate/1000)) %>% 
  mutate(Zone = str_extract(summary,"^.+(began|completed)"), Event = paste(Zone, subType)) %>%
  filter(str_detect(subType, 'ZONE_STARTED') | str_detect(subType, 'ZONE_COMPLETED')) %>%
  filter(str_detect(subType, 'ZONE_STARTED') | (str_detect(subType, 'ZONE_COMPLETED') & eventDate == max(eventDate)))  %>%
  select(eventDate, Zone, subType)

# Pull Minute Usage data from flume - limited to 1 day 
url <- "https://api.flumewater.com/users/115206/devices/<device id>/query"
payload <- "{\"queries\":[{\"units\":\"GALLONS\",\"request_id\":\"History\",\"bucket\":\"MIN\",\"since_datetime\":\"Start\",\"until_datetime\":\"End\"}]}" %>%
  str_replace('Start', Start_text) %>% str_replace('End', End_text)
encode <- "json"
response <- VERB("POST", url, body = payload, add_headers('authorization' = 'Bearer <secret code>'), content_type("application/json"), accept("application/json"), encode = encode)
ldata <- content(response, "parsed") 

# Convert list to dataframe
minWaterUsage<- do.call(rbind.data.frame, ldata$data[[1]]$History) %>% 
  rename(GalperMin = value)  %>% mutate(datetime = as.POSIXct(datetime))

# Use Rachio Zone run data to annotate Flume minutes
intervals <- c(Start, watering$eventDate, End)
labels <- c("Off", watering$Zone[1:NROW(watering)-1], "Off")
minWaterUsage$Zone <- cut(minWaterUsage$datetime, intervals, labels = labels)

DaySummary <- minWaterUsage %>% group_by(Zone) %>% summarise(Gallons = sum(GalperMin), Minutes=n())

# Plot the overnight sprinkler run
minWaterUsage %>% ggplot(aes(x=datetime, y=GalperMin, fill=Zone)) + geom_col() + theme_bw() +
  xlim(c(Start, End)) +
  ggtitle("Flume Flow vs. Sprinkler Zones") + ylab("Gallons per Minute") + xlab("Time")
1 Like