Daily average of a temperature
Show older comments
Hi all,
I have a ds18b20 and esp8266 with espeasy which posts a temperature reading to thingspeak every 5 minutes, works without any issue.
I want to have multiple fields to be able to show a daily average. I think this is not possible with espeasy directly so i have to get some workaround with the visualizations. I have the code below to show an average, it outputs a number, but nothing is plotted.
% Read temperature over the past hour from a ThingSpeak channel
readChannelID = 1462749;
TemperatureFieldID = 1;
readAPIKey = '__REDACTED__';
% Get temperature data for the last 60 minutes
[data, timeStamps ] = thingSpeakRead(readChannelID,'Fields',[TemperatureFieldID], 'NumPoints',30,'ReadKey',readAPIKey);
% Calculate the average temperature
avgTemperature = mean(data);
display(avgTemperature,'Average Temperature');
% Plot temperature and timestamp
plot(timeStamps,avgTemperature)
ylabel('temperature (°C)');
1 Comment
colm carmody
on 9 Feb 2022
Did you solve this issue I have the same problem, I can compute the average but not plot it.
Answers (2)
Yongjian Feng
on 3 Aug 2021
Your avgTemperature is just a scalar, a single point. Maybe you want to plot the data instead?
plot(timeStamps, data)
10 Comments
Matthias Borremans
on 3 Aug 2021
Yongjian Feng
on 3 Aug 2021
What do you mean by plotting average? avgTemperature is just a single point. You want to draw a single dot in the figure?
Your timeStamps is an array of 30, your avgTemperature is a scaler, a single average of all 30 temperatures.
Matthias Borremans
on 3 Aug 2021
Yongjian Feng
on 3 Aug 2021
You need to review the ThingSpeak document.
Right now, your code just read 30 temperatures from ThingSpeak and then computes the average of these 30 temperatures.
You might need to
- figure out how to read multiple temperatures for a given day, and then do an average
- Use a loop to loop through all the days you want to check.
Matthias Borremans
on 3 Aug 2021
Yongjian Feng
on 3 Aug 2021
Still confused about what you want to plot. You need to have an array of averages if you want to ploth averages, but here thter is only one.
Or say when you call plot(a, b), both a and b shall be arrays and they shall have the same size.
Matthias Borremans
on 3 Aug 2021
Yongjian Feng
on 3 Aug 2021
I see. So first you need to compute the dailyAverages, not just one single average as shown in your code.
Matthias Borremans
on 3 Aug 2021
Yongjian Feng
on 3 Aug 2021
How about this:
- Use a for loop to loop through all the days you want to plot.
- Inside the loop, get the temperatures of that particular day, and do an average
- append this average to an array, inside the for loop
- once the for loop is done, you have an array of averageTemperatures
- Plot that array.
Christopher Stapels
on 9 Aug 2021
0 votes
You can use the pencil icon on the top of the ThingSpeak plot to make the timeScale Daily.
Also, you can write the output from the code above to another ThingSpeak channel. We call that a derived channel.
Instead of 'NumPoints',30,
use 'NumDays', 1.
Use thingSpeakWrite() to write the data to you new channel.
And then use a timecontrol to call that code daily. Then you will have a plot of daily average.
Also you could create a matlab visualisation that reads many days of data and then use retime() function to calculate the daily avarage and plot it.
I reccomend using 'outputformat','timetable' when you read the data becasue retime works nicely on timetables.
Communities
More Answers in the ThingSpeak Community
Categories
Find more on Downloads in Help Center and File Exchange
Products
Community Treasure Hunt
Find the treasures in MATLAB Central and discover how the community can help you!
Start Hunting!