This page contains the complete release history of CumulusUtils as a reference. It is not meant to be a linear read but should be searchable.

Version 7.0.0 (xx/xx/20xx)

Major Work In Progress on a transition to .NET 6 (in parallel with similar work on CMX).
During this work development on version 6 has stopped, only support maintenance when required takes place.

  1. Created a new project line for .NET6. When CMX is ready for .NET6 CumulusUtils will follow shortly after.
  2. Dayfile and Standard Logfiles are now sourced through SQLite.
  3. ExtraSensor data are now sourced through SQLite.
  4. WindRose has now a much better performance because of the use of SQLite (3 times faster or better depending on the system/OS).
  5. Use latest versions of libraries. This may have effect on FTP, FTPS and SFTP. Standing issues to test in the beta:
    1. FTPS - not all servers were able to handle re-use of resource.
    2. SFTP - login with just un/pw does not work everywhere, thought to be provider dependent.
  6. Renewed compliance to W3 markup validation.
  7. Logging: moved some messages to different classes (Tracing, Info, Warning, Error). In general the view of the logfile improved with less messages (up to level Info).
  8. AirLink: Used SQLite to add the Windbarbs to the charts.
  9. ChartsCompiler: Used SQLite to add plot data to fetch the UserAskedData.
  10. Windrose bug fix: the v3 WindRose apparently had a bias to some directions/windspeeds which could not be found. The new technique with SQLite solves that issue.
  11. ExtraSensors: If the ExtraSensors remain open for more than 10 minutes (or multiples thereof) the ExtraSensor charts are reloaded. With this the ExtraSensors have the same feature as the Home charts.

Version 6.23.3 (xx/xx/23)

  1. ChartsCompiler: Error message improvement

Version 6.23.2 (10/01/23)

  1. ExtraSensors: Fixed. The Lightning and CO2 sensors were incorrectly handled when both present
  2. SysInfo: If the parameter Tx (for WLL) is not filled in, the resulting SysInfo page will show an error: "A value for the Transmitter used is needed - please set parameter Tx"

Version 6.23.1 (05/01/23)

  1. Graphs: When creating the solar energy chart, the solar energy per day can be requested and will be written out to DailySolarEnergy.csv. The parameter involved is [General] NeedSolarEnergyDailyValuesInCSV=false (default)
  2. Language: Parameters LimitValues, Winter1, Spring, Summer, Autumn, Winter2 have been added to the language file to be translated.
  3. Charts: All axis involving Temperature will now - when using Fahrenheit scale - have a soft minimum of 32 F-degrees i.s.o. 0
  4. General: It is now possible to run CUtils from day one i.e. after having at least one rollover i.e. the dayfile has at least one record.
  5. ExtraSensors: Fixed a unreported issue with the lightning sensor
  6. Graphs: Fixed a minor issue with the normal and station reference lines in the Daily Rain chart
  7. SystemInfo: With the WLL device you now get a message if the Tx parameter is not filled in

Version 6.23.0 (06/12/23)

  1. Technical: A cleanup of the code wrt the JSON creation. Though this is not visible for the user it has impact and will require (international) regression testing.
  2. Technical: Redo the logfile reading along the line of the CustomLogs. This reduces complexity and unifies the method. Not visible for the user and will require (international) regression testing.
  3. Technical: Performance gain while reading the monthly logs as a result of the previous action.
  4. MeteoCam: Addition of EcowittHP10 as CamType (the original being the default CamType Manual)
  5. Language: parameters NormalYearlyRainfall, StationYearlyRainfall, DailyRain, DailyEVT have been added.
  6. Graphs: In Rain vs EVT chart the plotline Normal Yearly Rainfall has been moved to he front and colour set to blue. The default title has the addition "Cumulative". The user who already has this in the language file will need to change it manually.
  7. Technical: Deprecated the use of MySQL (i.e. the parameter UseSQL is no longer used and can be removed)
  8. CustomLogs: Webtag wchillH has been renamed wchillL from CMX b3264 and up.

Version 6.22.0 (23/11/23)

  1. Units: fix for Distance as that was always km and should be corresponding the windspeed (mph => mi, m/s => km etc...)
  2. CustomLogs: addition of the following webtags: RecentApparent, RecentIndoorTemp, RecentIndoorHumidity.
  3. Graphs: addition of Rain versus EVT graph (in the Rain section)

Version 6.21.5 (16/11/23)

  1. Sysinfo: Added reception status for Ecowitt devices
  2. Airlink and ChartsCompiler: WindBarbs is now a translatable word
  3. ChartsCompiler: added an Axis Height (ToDo: Wiki compiler spec.)
  4. Customlogs: Changed permitted webtag cloudbase to cloudbasevalue and attached axis Height
  5. Website: The pwsFWI button which in the past had been moved from the navbar to the header, has now been made configurable. If you add PwsfwiButtonInHeader=false to your [Website] section of cumulusutils.ini it will configure in the navbar just before the system led. The default for this parameter is true (placing the button in the header). Editing cumulusutils.ini yourself saves the labour of a second website run.
  6. CustomLogs: added the following webtags to the allowed webtag list: "windrunmonth", "StormRain", "RecentOutsideTemp", "RecentWindChill", "RecentDewPoint", "RecentHeatIndex", "RecentHumidity", "RecentWindSpeed", "RecentWindGust", "RecentWindLatest", "RecentWindDir", "RecentWindAvgDir", "RecentPressure", "RecentRainToday", "RecentSolarRad", "RecentUV", "RecentWindChill", "RecentFeelsLike", "RecentHumidex", "snowdepth", "snowlying", "snowfalling", "Tbeaufortnumber".
  7. Customlogs: webtags in the realtime table in the left pane are now displayed including the brackets and the hash (<# >) to facilitate the showing of possible modifying parameters.

Version 6.21.4 (12/11/23)

  1. General: Fixed: Improved logging info when asking webtag values
  2. CustomLogs: made the realtime table animation slow
  3. ExtraSensors: Changed the realtime table height to 70vh
  4. Uploading file: Fixed: The CMX Host parameter is only for FTP protocols. When using PHP upload PHP-URL needs to checked for not empty
  5. CustomLogs: If the CustomLog Frequency in minutes modulo the Internet Interval in minutes has a value other than zero, a warning is logged when the end of the log is reached and the last record time does not match the endTime.
  6. ChartsCompiler: Introduction for a specific path on the website when making modular use of CUtils and wanting to separate CUtils from the webroot files. Introduction of the parameters DoModular (cannot be combined with the Website command) and ModularPath which contains the path to the CUtils modules, relative to Webroot e.g. CUtils/ (the closing slash is required as it is with CumulusRealtimeLocation). NOTE: Module and ModularPath does not hold for the AirLink module which is on the ToDo-list for Modular handling.
  7. CustomLogs: Added THWindex and THSWindex to the list of allowed webtags

Version 6.21.3 (07/11/23)

  1. CustomLogs: Fixed: The Ecowitt CO2 sensor has also an AirQuality sensor with four values which need an AQ axis.
  2. Website: Modification of website statistics parameters adding Matomo for a choice between Google and Matomo. Parameters have changed, see wiki. If you already use Google statistics, you will need to set the new parameter StatisticsType to the value Google (the default for this new parameter is empty).
  3. CustomLogs: Modified the layout and behaviour of the realtime values table in the left pane in relation to the chart chosen (length of table with overflow and a slideDown when change from RECENT to DAILY and vice versa.

Version 6.21.2 (04/11/23)

  1. CustomLogs: Fixed - When reading the logfiles over a month boundary the transition to the next month was incorrect Thus the charts were missing the days in the new month.
  2. CustomLogs: Modified the CustomLogs - using the units and charts axis.
  3. Chartscompiler: solved a few bugs while implementing the CustomLogs Units and chart Axis. Non-critical in pre-6.21 versions

Version 6.21.1 (31/10/23)

  1. CustomLogs: Fixed - When using CumulusRealTimeLocation the customlogs JSON's were not correctly located.

Version 6.21.0 (22/10/23)

All functionalities of the previous beta's

Main addition is the implementation of the CustomLogs module. CustomLogs will:

  1. Make it easy to chart Lightning with the Ecowitt Lightning sensors (see below)
  2. Makes it possible to plot previously unavailable values (E.g. the Wet Bulb Temperature or 24 hour rain)
  3. ... and whatever users may come up with - all webtags producing a value are available for plotting

The CustomLogs module is also accessible as a module for displaying the charts in other websites. The realtime table is generated but not compulsory to use (using it in an other website requires additional handling and its use becomes more complex). Data will be supplied daily by the CUtils USerAskedData call.

If a you create a CustomLog with the webtag <#LightningStrikesToday> - the Daily frequency is best as it is a daily total - automatically a chart with the daily number of strikes will be created when the module is activated.

Default the CustomLogs are under the menu Extra. If the user chooses eventually a manual handling of those charts he can use that chart anywhere.

Once configured, CustomLogs are a very powerful tool to chart any value available in CMX in any combination. A picture - i.e. a chart - says more than a thousand words.

Checkout the ToDo list for version 6.22.0 and possibly propose a suggestion.

Additional modifications since last beta:

  1. No more crashes when adding a webtag to an existing log
  2. All file copies created while running the module are now correctly removed
  3. Incremental now works only for a UserAskedData run
  4. For an Ecowitt device added the firmware version in SysInfo (when available)
  5. Webtag #CPUTemp is added to the list
  6. Webtag name comparison to the reference list is now case dependent (as it should be). So a case spelling error now correctly fails the webtag!

Version 6.21.0 beta 1 to 4 (10/10/23)

  1. SysInfo: A distinction can be made for various Linux dialects when required. If needed contact me and we'll work it out.
  2. Sysinfo: openSUSE (Tumbleweed) has been implemented as Linux dialect.
  3. Forecast: SpotWx has been reinstated as default to prevent a crash while doing a new install.
  4. Units: When using m/s for speed, distance will be expressed in Km (distance in m is never used by CUtils).
  5. Graphs: Fixed the conversion of X-axis day number to date in the tooltip when applicable, when graphs used as module (not sure what happened here so report if not working!).
  6. General: Added the device types according to CMX v3.27.0 - b3250
  7. Gauges: Modified CUgauges.js to sync with gauges.js 2.7.7 of CMX 3.27.0 b3250
  8. CustomLogs: A first beta for a CustomLogs module. See the Wiki page and the forum post specifically for this beta.

Version 6.20.0 (21/7/23)

  1. Website: IMPORTANT => Files borrowed from CMX and (possibly) modified - notably: gauges.js, gauges-ss.css, language.js, RGraph.common.core.js, RGraph.rose.js, steelseries.min.js, tween.min.js - have been prefixed with CU. You need to do a full update i.e. with one run without thrifty. The reason for this is that some users started using the libraries from the CMX release and use all websites from the same directory. You should not do that and it will fail the system (For CumulusUtils or for your alternative website depending which is last placed in that location).
  2. Website: Please note that the CMX Default Website Development is developing fast and the new Alternate Default Website changed its index filename to index.html (it always was index.htm). index.html is the same name as for the CumulusUtils website so you can no longer have those two websites in the same directory! The advised setup is always to create separate directories on the server for any website you create (which btw most of you, but not all, do). The data access is relative through the parameter CumulusRealTimeLocation and the Alternate Default Website will have a similar feature as promised by Neil.
  3. Heatmap: The heatmap colour axis now has a range from 0 - 100 for the Fahrenheit scale for better resolution

Version 6.19.0 (29/06/23)

  1. General: some minor formatting corrections for use of imperial units
  2. General: Error correction and handling improved in case of an erroneous locale (in cumulusutils.ini)
  3. General: All dates displayed in the modules and website are now shown according to the locale defined in the language setting in cumulusutils.ini:
    1. Records: The Records, DayRecords and Top10 pages have been reworked to display the date/time in the local format used.
    2. pwsFWI: Adjusted for date formatting
    3. Graphs: Date in clock pane now follows local format.
    4. Gauges: Corrected the Danish language code to da i.s.o. DK and did that also for the gauges, this should be transparent for the user (Note the Danish locale is: da-DK).
    5. General: With this version, the use of the locale has been formalised. Please make sure you use the locale for your language/country as defined in this Microsoft document.
  4. HighCharts: All charts in CUtils will now display short dates (i.e. dd/mm/yyyy) according to the locale. This only is seen in the tooltips (e.g. the heatmap and Temperature Sum)
  5. Charts Compiler: To accommodate the mix of scatter with other plots, only the main y-axis (the first in the definition) now generates its gridlines, and the ticks for the different y-axis are no longer aligned. This will give a slightly different experience for the charts.
  6. General: Correction for the distance unit: meters is now possible (btw: not accessible for the user)
  7. Charts Compiler: The Distance Axis now works (Note: unit has to be reworked)

NOTE: It is understood that Norwegian, Danish and probably Swedish show different output for the C# compile time or for the javascript runtime.

Version 6.18.3 (10/06/23)

  1. Forecasts: Text around the Yourweather forecast table is now translatable (section: Forecasts)
  2. Forecasts: Default ForecastSystem is reset to YourWeather because SpotWX has an issue with cookies. If you have set SpotWX and want to change, please modify parameter ForecastSystem to YourWeather.
  3. Top10: Long Dry/Wet periods. Make sure the current period is taken into account when the period is not yet finished.
  4. Parameters: CMXport has been moved to section General. UseSpecificHighchartsVersion has been added to section General to facilitate the user who wishes to use a specific Highcharts version. If empty automaticly the last published version is used. If a specific version (e.g. 10.3.2) is entered then that one is used. No slashes, no spaces just <number>dot<number>dot<number>
  5. General: Some minor formatting changes for imperial units, this includes an axis boundaries change for the heatmap.

Version 6.18.2(05/05/23)

  1. Website: The value of MoonImageLocation was forced lowercase which was incorrect.
  2. Month files: While reading the month files it had internally a max number of errors (value 10) after which it stopped logging. That value is now parameterised inn section general. It has no influence on the processing of the files, just the logging of the errors.
  3. Month files: Fix for correct order of assignment in case of older logfiles where values may be missing (e.g. if EVT is not present, SolarRad is now read correctly).
  4. Top10: Removed a line which cause unexplained errors on an RPi. It is still unexplained what and why it happened so all RPi users are asked to check the logs once in a while and look for errors. Errors may appear as crashes or graphs not appearing at all. So far the cause seems to be in the environment but a true explanation has not been found.

Version 6.18.1(30/04/23)

  1. AirLink: The AirLink Help button now is upgraded to Bootstrap 5.2 (it did not open/close properly)
  2. Airlink Help: Corrected a broken link on the help page.
  3. pwsFWI: Fix for dry/wet periode: when a day rain amount is less than 0.2 it is not counted as rain so dry period continues
  4. Moon image: To avoid confusion when your site is used by more than one CMX instances and more than one CUtils sites, the moon image location is now always made explicit. Use: MoonImageLocation=<Full URL>. Include the image name in the URL! (best to manually add it to cumulusutils.ini and run website)

Version 6.18.0 (24/04/23)

  1. PHP upload: UTF8 header added. You need to use this CUtils version (and up) to use PHP upload with CMX 3.25.x and up
  2. Charts Compiler: Code generation creates a global for windbarbdata to prevent apparent issues.
  3. Top10: Fixed a bug for the wet/dry periods. Those are now correct.
  4. Airlink: Winddata are now fetched through the API for both incremental and full json data upload (requires 3.25 as well)
  5. DayRecords: The report is now independent of thrifty to have correct formatting and prevent out of date reports
  6. Helptexts: The titles of the Helptext modal screens for the Graphs module now have titles fitting the charts they belong to (and not "Daily Rain" as it was)

NOTE: It is required to use CMX version 3.25.0 (and up) with this version of CUtils (and up).

Version 6.17.3 (15/03/23)

  1. General: technical wrap up of the past quick successive releases
  2. General: Sync up to CMX 3.24.2

Although no functional changes it is advised to update. If any anomalies please report.

Version 6.17.2 (13/03/23)

  1. UserAskedData: Fix for duplicate CO2 sensor entries in the ExtraSensors JSON for Ecowitt CO2 sensor. Required for PHP upload (incremental uploads)
  2. General: Fix for a wrong DateTime format in RecordsBeganDate generating a crash. If format is not correct (must be dd/MM/yy) then the date is reset to first date in database and a warning is issued in the logfile.
  3. Upload: Fix for CUtils upload to other directories than the location of upload.php. The UploadDir in section FTP site is now taken into account

Version 6.17.1 (08/03/23)

  1. Parameter DoneToday: For both parameters DoneToday the format is now set as ISO to prevent an error caused by mono for some locales
  2. ExtraSensors: The module ExtraSensors now correctly translates the plotvariables, defaults come from strings.ini (see wiki)

Version 6.17.0 (05/03/23)

  1. Top10 & DailyRecords: parameter UseScrollableTables. When false no scrollbar or defined height is shown for modular use, when true otherwise. Released as patch 1 to version 6.16.0
  2. General: Introduction of parameter RecordsBeganDate in section General (independent of CMX parameter StartDate). When set to a date (format: dd/MM/yy) it will be used as the startdate of the data in charts and reports no matter the actual startdate in dayfile or monthfile.
  3. Uploads: Introduction of the PHP upload protocol present in CMX version 3.24.0 and up
  4. Menu: The menuitem Print is added (add to CutilsMenu.def (top level) if you want to use it). This provides the possibility to print what is in the ReportView.

Version 6.16.0 (12/02/23)

  1. ExtraSensors: Fix for Ecowitt AirQuality sensors typo (released as patch 1 to 6.15.6)
  2. Top10: records now has top 10 list of minimal rain per month added. Technical update of this module
  3. Top10: records now also has a scroll bar (on the containing div)
  4. YADR: Fix for nr of decimals for the Rain report when using inches
  5. Misc Graphs: Fix for the season chart which is now corrected with an addition of 10 days to winter 1 (counting not the start but the end of the 10 day temperature grace period)
  6. Fix gauges.js: The init was done at document ready which made the modifications ineffective. Init is now after the modifications.

NOTE: This is the first major update for the oldest module of CUtils ;)

Version 6.15.6 (30/01/23)

  1. Functionality of 6.15.6 but now working correctly

Additional modifications:

  1. ChartsCompiler: Fix for the units of the ExtraSensors
  2. ExtraSensors: Fix for realtime values for the ExtraSensors
  3. Lightning Sensor: Added the date to the time of last strike
  4. Lightning Sensor: Whichever unit the distance it is always presented rounded to the nearest integer

Version 6.15.5 (29/01/23)

  1. General: The number of solar hours has a non-translated unit hrs. This is removed as the description label is sufficient.
  2. ExtraSensors: Added the Lightning Sensor. Activate with parameter LightningSensor=true.
  3. ExtraSensors: Added coulour changeindicators (using the same colour as main dashboard: ColorDashboardTextAccent).
  4. StationMap: Reshuffled the code for the rotation of map objects. Now the map loads correctly after the User map (which it didn't, might you not have noticed it)
  5. Unit Pressure: Pressure in hPa is now in one decimal (to get better distinction in Records modules) and in inHg is now 2 decimals.
  6. Chartscompiler: Fix for pressure with a decimal comma (locale dependent) is now always converted to a decimal point for the Dashboard.

Version 6.15.4 (16/01/23)

  1. General: When a unit rate of change is displayed it was /hr or /h in all languages. Now it can be translated through the PerHour translation tag in section [General]

Version 6.15.3 (12/01/23)

  1. General: fix - forced some configuration parameter values to be lower case (so True is read as true)
  2. ChartsCompiler: When loading a charts collection (e.g. cumuluscharts.txt) the version of HighCharts is now displayed in the console
  3. Highcharts: fix - the version of Highcharts to version 10.3.2 to make the INFO keyword work again and because the colour bug has been fixed
  4. Highcharts: added thousandsSep = "" to the HighchartsLanguage.js (set the thousands separator to empty string)
  5. Graphs: The heatmap now has a normal date in the tooltip
  6. Graphs: changed the fourth default value for GraphColors to #ed9b00 (darker goldish) i.s.o #DDDF00 (hardly visible yellow)
  7. StationMap: Position of the Arrow now is fixed -0.02 degree longitude from the station marker, map is centred on the station marker.
  8. Wiki: added an explanation of the scaling of the charts on the CDL page.

Version 6.15.2 (04/12/22)

  1. ChartsCompiler: Fix - Keyword INVISIBLE can now also be used at the end of the PLOT definition line.

Version 6.15.1 (02/12/22)

  1. ChartsCompiler: Addition of the Keyword INVISIBLE to suppress a chart line at initialisation of the chart

Version 6.15.0 (27/11/22)

  1. ExtraSensors: Major rewrite. Configuration now through inifile parameters, strings.ini is now secundary. Thanks for the help while testing :D
  2. Website: Correction for the night image for the header (which was never selected)
  3. Website: The generation date in the version strings is now "g" i.e. the short format in the locale CUtils is running in. Note that the date in the clock can be different format because that comes from CMX.
  4. Website: Some minor corrections in spelling and messages for the console
  5. Pressure charts: The max and min values are now handled to accommodate the imperial units (inHg)

Version 6.14.4 (22/11/22)

  1. ChartsCompiler: The yAxis for pressure now displays the units according to the a new formatter (2 decimals for inHg and 0 decimals for mb and hPa)
  2. Website: When using inHg as pressure unit, the realtime dashboard not displays 'inHg' i.s.o. 'in' (just as everywhere else)
  3. Record: The records page now starts <AllYears>/<Current Month> similar to DayRecords (which starts in <Current Month>).
  4. Highcharts: Fixed the Highcharts release to 9.1.0 (in line with CMX) to prevent error regression with new releases (which appear to occur too often)
  5. Highcharts: The tooltip for the (average) bearing is now correct.

Version 6.14.3 (19/11/22)

  1. HTTP: For HTTPS sometimes the connection fails on the SSL layer for unknown reasons. This issue has now been circumvented.
  2. Website: Unit for Elevation was always in meters. Now, when given in feet, it shows the correct unit (ft)
  3. Graphs: The Temperature HeatMap now also works properly for Fahrenheit
  4. Units of Pressure: Internally the pressure unit was read from CMX through the wrong parameter name therefore it was always hPa. That is now corrected.

Version 6.14.2 (03/11/22)

  1. ChartsCompiler: The Windbarbs now have a tooltip which shows the wind unit used on the site (it was m/s).
  2. AirLink: As in ChartsCompiler.

Version 6.14.1 (31/10/22)

  1. ChartsCompiler: And in the process of the previous fixed a bug on EOF detection.
  2. Website: Drop down user menu's are now automatically adjusted in width to accommodate large width multiword menu choices
  3. Website: The Extra top menu is not generated if there is no AirLink and No Extra Sensors preventing erroneous formatting of the menu.

Version 6.14.0 (22/10/22)

  1. Website: Menu System 2 is released. See Wiki.
  2. ExtraSensors: AirQuality sensors do have the current value and the 24 hr average value (two sensors in one). If the 24 hr average sensor has not been identified/named by the user in strings.ini, it will receive a default name to prevent corrupting the system.
  3. StationMap: activated the weather data below the arrow.
  4. Charts Compiler: The default CutilsCharts.def in the distribution has been updated to reflect Windbarbs and Zoom keywords.

Version 6.13.1 (10/10/22)

  1. General: (6.13 patch 1) Cutils now runs on MacOS too (detection of OS Darwin). NOTE: SysInfo needs to be worked on with the user)
  2. Website: (6.13 patch 2) Bugfix for display of the date when the date separator is a point.
  3. ExtraSensors: (6.13 patch 3) Bugfix for reading the double amount of data from the logfile (rounding down error for start/end time to 0 seconds)
  4. HelpSystem: Now all graphs work with the Info system (NOTE: Only the WindRose does not work is still problematic)

Version 6.13.0 (08/10/22)

  1. ExtraSensors: Bug fix for passing a month boundary when rollover time is other than midnight (9 or 10 am)
  2. Graphs: Addition of a help system for the Graphs (the climate charts) analog to the Info keyword of the ChartsCompiler. See the Wiki page.
  3. Language: The word Info has been moved to the section General of the CUstringsXX.ini. You can remove it from the section Compiler.

Version 6.12.2 (28/9/22)

  1. Extra Sensors: Bug fix for risk of duplicate Temperature chart under the English language

Version 6.12.1 (28/9/22)

  1. Addition of ZOOM keyword in CDL (see wiki)
  2. Clean up of the Chart block in the wiki
  3. Menu System2: The menu definition file now can contain blank lines (no further additions)
  4. ChartsCompiler: The word Info was erroneously placed in cumulusutils.ini and has been move to the language file (you may remove it from cumulusutils.ini)
  5. Logging: Several corrections and modifications in severity in the messages
  6. Extern Extra Sensors: A fix for a possible error condition during a month boundary transition.
  7. YADR: a fix for the windrun classes when dimension is other than km

Version 6.12.0 (22/9/22)

  1. ChartCompiler: The keyword Info on a chart was introduced. When used on a chart the word Info appears left of the chart exporting menu. When clicked, a modal popup is displayed with the user specified help text. See the Wiki for further specification.
  2. Website: System 2 for the user defined menu has been introduced (in beta, See wiki)
  3. Logging: Reduced the verbosity in the log while generating the rain and temperature graphs.
  4. Gauges: Contains the fix for the bug CumulusRealTimeLocation in 6.11.0 which previously was published as a patch

Version 6.11.0 (10/09/22)

  1. Website: Bugfix - The positioning of the odometer suddenly started to fail on some hardware/browser combination. A fix was released comprising of a change in gauges.js and gauges-ss.css adding the odo class. To facilitate those changes the website code had a minor change.

Version 6.10.0 (03/09/22)

  1. AirLink: Bugfix - a correction in the order of the CMX AQI formula's as used in CUtils (selectable in CMX: CA comes after EU and not before!)
  2. ExtraSensors: Bugfix - Corrected the unit in the tooltip of the CO2 temperature line (Ecowitt WH45)
  3. ChartsCompiler: Bugfix - Corrected an issue with the scatter charts which was highlighted with the v10 release of Highcharts and which also had an issue in Chrome (see previous post)
  4. Website: Corrected several HTML Markup Validation errors in the index.html
  5. AirLink: The Referenceline thickness is now configurable (default = 4) through parameter ReferenceLineThickness
  6. Website: Upgraded the website to Bootstrap 5.2 This has consequences for your CUsermenu.txt. The data-toggle='dropdown' must be replaced by data-bs-toggle='dropdown' and dropdown items are no longer <span> but <ul> <li> combinations. Checkout the CUsermenu-example.txt in the distribution for the changes.
  7. General: Upgraded the libraries: FluentFTP, ServiceStack.Text, MySqlConnector

Version 6.9.9 (10/08/22)

  1. Libraries: Updated FluentFTP.dll, ServiceStack.Text.dll and MySqlConnector.dll to their latest versions (38.0.0; 6.2.0 and 2.1.11)
  2. Website/General: Technical update for signature files
  3. InetSupport: Some minor changes in FTP/FTPS handling
  4. ChartsCompiler/Windbarbs: Windbarbs are now (almost) equidistant for any nr of days plotted.
  5. AirLink: The identification of the United Kingdom in the parameter CountrySelected (section AirLink) has changed to UK iso GB to make it analog to CMX.

Version 6.9.6 (08/07/22)

  1. Website/General: Allow for images as background to charts. Note that this does not necessarily work when used modular.
  2. ChartsCompiler: bug fix - allow for STATS function(s) to use EXTRA plotvars
  3. ChartsCompiler: Small experiment => Removed the limitation on scatter series to be combined with other types.
  4. General: some cleaning up of old code.

Version 6.9.5 patch 1 (02/07/22)

  1. ChartsCompiler: bug fix - related to (EXTERNAL) EXTRA sensors
  2. ChartsCompiler: bug fix - use CumulusRealTimeLocation when reading winddata for the WindBarbs
  3. ChartsCompiler: bug fix - have the colour of the WindBarbs configurable to stand out against any chart background colour (implemented in CDL)

Version 6.9.5 (01/07/22)

  1. Extra Sensors: Completed the External Extra Sensor functionality (see this post)
  2. ChartsCompiler: Completed the Windbarbs feature in CDL (see this post)
  3. General: Disabled the ALL commandline parameter to avoid the apparent confusion it being a partial website commandline parameter

Version 6.9.2 (26/06/22)

  1. Compiler: Added the optional language construct "Has WindBarbs [Below | Above]". See Wiki CDL. This feature is beta.
  2. Fix AirLink: Reading the AirLinkLog required an additional condition for preventing an infinite loop (and running out of memory/swap).
  3. Fix Airlink: The windbarb xAxis on top is now aligned with the xAxis below
  4. Fix MeteoCam: Corrected the Upload for the MeteoCam output when the user does not use it.

Version 6.9.1 (16/06/22)

  1. UserAskedData: DayEVT now correctly gets the data in the CUserdataALL.json
  2. SFTP: A workaround if the ECDSA cipher is asked is now implemented similar to CMX

Version 6.9.0 (14/06/22)

  1. Cutils runtime library: one minute UpdateInterval (see CMX FTP parameters) is now acceptable
    NOTE: this is meant for local webservers and not for internet transfers.
  2. ChartsCompiler: Changed keywords in the ALL/DAILY set of keywords to prevent conflicts with the RECENT keywords. Check the CDL Wiki (check your chart definitions!). The changed keywords are:
"AvgWindChill" (was: "WindChill")
"HighAvgWindSpeed" (was: "WindSpeed")
"DayRain" (was: "RainFall")
"DayEVT" (was: "EvapoTranspiration")
  1. ChartsCompiler: fine tuned the rain and rainrate axis : the last label (highest number) is now shown and the rain/rate gridlines are only shown when not disturbing other gridlines.
  2. AirLink: AirLink charts now too works with 9 am (and 10 am) rollover hour (phew...)
  3. Map: If no link is given for the website it is now clearly indicated in the pop-up.
  4. Website: Multiple header image selection at runtime now actually works
  5. General: the software libraries have been upgraded

Version 6.8.3 (03/05/22)

  1. ChartsCompiler: Bug fix: when no or very little rain occurs over the whole selected period the max y-axis keeps too high value for e.g. inches.
  2. General: The usage message is now shown as a first action when no arguments are given (i.s.o. first initializing FTP and Dayfile)
  3. SysInfo: Added WLL statistics
  4. Sysinfo: Added inifile parameter ExtraStationInfo to enter free format information for non-Davis stations.
  5. Website: Multiple header images are now possible for each phase of the day: DAY, CIVIL twilight, NAUTICAL twilight, ASTRONOMICAL twilight and NIGHT. See the wiki.
  6. Day records table has now possibility to scroll (configure UseScrollableTables=true (default)), section [General]). DayRecords and pwsFWI modules now use thin scrollbar which does not work in chrome.
  7. Map: Users will now always appear on the map, the link to their site is no longer compulsory (but highly appreciated).

Version 6.8.2 (19/04/22)

  1. Fix: some glitches in the handling of the low limit of the rainfall
  2. Change: for a clean install take care the FTP/UploadDir gets in the inifile on the first run so it is easier for the user to continue.
  3. Change: Now the defaults for DoLibraryIncludes & GeneratejQueryInclude parameters is false; When using CUtils in a modular fashion set these to true.
  4. AirLink: Created the possibility to use the module as a standalone page (just a html page with the data in current directory, no other context required).
  5. Wiki: important modifications wrt Language in Utils / Trouble in Paradise and Dependency of the ExtraSensors on the use of the ChartsCompiler.

Version 6.8.1 (03/04/22)

  1. General: Overhaul of units and (internal) unit conversions because imperial units are being used now seriously (mi and inches).
  2. graphs: Wind graphs / Windrun chart - adjusted the tooltip to clarify better.
  3. ExtraSensors: ExternalExtraSensors remains in beta until (probably) end of may. Notice will be given when usable.
  4. Please note that the modified Wind Chart Wiki is also part of this release wrt the legend.

Version 6.8.0 (29/03/22)

  1. UserReports: Introduction of Cutils dedicated webtags. Currently only <#CUversion>. Released as a patch for 6.7.14 on 28 march
  2. ExtraSensors: Bug fix to prevent reading the log for every sensor. Now read only once.
  3. Logging: Created the possibility to switch logging completely off. Parameter: LoggingOn.
  4. Logging: Console Messages are regulated by parameter NormalMessageToConsole which is independent of other settings.
  5. ExtraSensors: ExternalExtraSensors are still in beta

Version 6.7.13 (27/03/22)

  1. Graphs: Correction for the southern hemisphere for the temperature sum and seasons charts.
  2. Extra Sensors: Addition for External Extra Sensors in beta.

Version 6.7.12 (not released)

  1. Top10: Ecowitt registers rain with 0.1 mm precision. For the dry and wet period records in top10 a rainfall of 0.1 mm is ignored.

Version 6.7.11 (03/03/2022)

  1. ChartsCompiler: Bug fix: When using the ChartsCompiler, it now also initialises correctly when using the OUTPUT specifier or the ExtraSensors module.
  2. Graphs: Bug fix for Solar hours chart - the ratio between Solar Radiation and Max Radiation (determining the hours of sunshine) had a conversion error (integer to float)

Version 6.7.10 (26/02/2022)

  1. ChartsCompiler: Bug fix: When using the ChartsCompiler stand-alone (CompileOnly), the output can now be used in the CUtils website

Version 6.7.9 (26/02/2022)

  1. Charts (Home and ExtraSensors): Fixed a bug in the initialisation which in some cases showed a weird value for the last point plotted
  2. Changed the fourth default chart colour (see HighchartsDefaults.js) from #DDDF00 (yellow) to #ed9b00 (yellowish gold orange)
  3. ExtraSensors: Corrected a bug for LeafWetness sensor
  4. Sysinfo: Memory information now shows swap device too
  5. Some minor corrections

Version 6.7.8 (02/01/2022)

  1. Changed RECENT keyword 'SolarRadiation' to 'CurrentSolarRad' (see specification)
  2. An equation now requires an Axis spec or gets default Axis Free. If the Axis spec is missing only a warning appears in the log
  3. Bug fix for case independency which in equations sometimes was not correctly handled. Plotvariables are now really case independent, even in equations.

H/T AndyKF650 who did spend some serious time on testing all corners of the ChartsCompiler!

Version 6.7.7 (24/11/2021)

  1. Website: Fix for the initialisation of the gauges. Now the gauges init is called after the settings of the CumulusUtils user parameters.
  2. A total of three patches have been released with improvements as output of a day of testing by AndyKF650 (Thank you Andy for the effort!). The patches will be assembled into the next - and probably final release - of the version 6 series. Version 7 will be from a technological point of view a very different and non-compatible version.

Version 6.7.6 (23/11/2021)

  1. Forecast: Fix for new Norwegian forecast URL

Version 6.7.5 (22/11/2021)

  1. Website bugfix: Now you get the moon rise and set times with the CMX moon image as well (apologies for my release management recently)

Version 6.7.4 (22/11/2021)

  1. The moondisc now can be chosen to be the CMX moondisc (See the Wiki)

Version 6.7.3 (21/11/2021)

Equal to 6.7.2 but this time packaged correctly and also working under Windows 7.
Version 6.7.2 is withdrawn because of a packaging error affecting the libraries. This causes a problem on Windows, as fas as it is understood only on Windows 7.

Version 6.7.2 (20/11/2021)

A technical update related to ServiceStack.Text.dll (5.13.2) and Renci.SshNet.dll (2016.1.0.0)

Withdrawn.

Version 6.7.1 (25/10/2021)

  1. A patch version to get rid of a disturbing '>' above the index file in the website

Version 6.7.0 (25/10/2021)

  1. Infrastructure: Update to .NET Framework 4.8, Update of MySqlConnector (1.3.14), ServiceStack.Text (5.12.0) and SSH.NET (2020.0.1)
  2. Website: Upgrade to Bootstrap 4.6.0
  3. gauges.js: Added a console message 'Gauges Init Done... to have an anchor for debugging
  4. Dashboard: Added an empty header to an empty pane (configration of dashboars)
  5. Maps: Corrected some logic which made it possible for website users to evade the map. Now it is again obligatory (http address and Lat/Lon are compulsory)
  6. ExtraSensors: For the command line parameter ExtraSensors, now the CompileOnly parameter is implicit. This means that now the command utils/bin/cumulusutils.exe ExtraSensors is enough to create the resulting extrasensorscharts.txt
  7. ExtraSensors: The Extra Sensor identification string in strings.ini is now silently transferred directly to the [Compiler] section in the CUlangXX.ini file so that the legend display is immediately understandable without user interference. Any later change to that string has to be made through the language file. With a total reconfiguration of the Extra Sensors it is best to delete all Extra Sensor parameters in the language file compiler section.

Version 6.6.5 (14/10/2021)

  1. Technical: Upgrade of third party libraries (ServiceStack.Text; MySqlConnector; Renci.SshNet).
  2. Charts: Corrections on Daily Rain, Temp Sum, Growing Degree Days and Thermal Seasons charts for situations where not enough data exist to either create the moving average or the chart as a whole. As a work around you may simply switch the chart off until you have enough data, typically the Moving Average period (for the daily rain or EVT charts) or the first day of the year is valid start day (for the agricultural charts). This is only relevant if you are a new user of CMX and typically have less than a year of valid data.
  3. Charts: Code correction when data for a month does not exist in the statistical charts per month. Added a semicolon to make console logging possible (yes, semicolons are relevant in javascript).
  4. Technical: Initialisation of the gauge parameters was erroneously removed during the previous version 6.6 edits. Sorry for that.
  5. Dashboard: Now it is possible to move the Wind Gauges individually as well. See dashboard for an explanation. Note that to move events as well you need the ChartsCompiler, if you are a starter in CDL, please use the CutilsCharts.def from the distribution.

NOTE: this release requires to replace fully the contents of the utils and the utils/bin directory!
NOTE: this release definitely requires a full non-thrifty run to get the all generated code in line!

Version 6.6.1 (12/10/2021)

  1. Fix: If either CUsermenu.txt or CUserAbout.txt does not exist, the realtime.txt will not be read. You can either install this fix (only the executable is required) or create those (empty) files in the webroot.

Version 6.6.0 (11/10/2021)

  1. Compiler, AirLink, ExtraSensors: modules now behave properly under thrifty (meaning they will not update the code).
    Changes to the configuration as always will require a non-thrifty run.
  2. Internal: Finally unified all the ajax calls to the latest standards (users will not notice I hope but please report on any anomaly).
  3. Records: Fixed a bug for a translation tag for the Wind Run Distance. Now it shows correctly distance i.s.o. speed.
  4. General: Fixed an issue with certificates (Let's Encrypt) with the transition to OpenSSL 1.1.0. See also this thread on the forum and also this thread on Windy, note you land on a reply by Mark containing a clear action on how to deal with RPi (what is valid for Raspbian 8 you can also apply for Raspbian 9 & 10). If you don't, don't worry: CumulusUtils will still work.

The last point causes an additional requirement to use Mono 6 and up under Raspbian Linux. In itself this should not be a problem. If you update along these instructions you should have no problems. If Mono is on a lower version this is automatically detected and where required, specific access to https servers is avoided. This all is only required for the CumulusUtils user map so however unfortunate that you will be missing the map and won't be on it with Mono 5 and lower, all main functionality of CumulusUtils won't be touched.

Version 6.5.2 (16/9/2021)

  1. ExtraSensors: bug fix for the logic when extra sensor logging is off in CumulusMX and you're generating a website
  2. AirLink: bug fix in the filename for the ExtraSensors and AirLink logfile when chart period crosses a month boundary

Version 6.5.1 (16/9/2021)

  1. ExtraSensors: updated the layout of the table in the dashboard and text and background colour of the header now follow the general dashboard header settings
  2. ExtraSensors: Added some additional logging while writing the ExtraSensors Charts code
  3. ChartsCompiler: The Free axis (dimensionless) now has the "ChartsId + dimensionless" as axis title such that the user can give his own description (and unit) through the translation

Version 6.5.0 (13/9/2021)

  1. Release of the Extra Sensors module. For the functionality see the Wiki and the notes below, down to 6.1.2

Version 6.5.0 beta 3 (13/9/2021)

  1. Modified the text colour of the Extra Sensors table to follow the menu text (as the colouring follows the menu colouring)
  2. Revisited the reading of the ExtraSensors logfile to avoid double data (and an annoying horizontal line)
  3. Revisited the reading of the AirLink logfile to avoid double data (and an annoying horizontal line)
  4. Cleanup of the Airlink and ExtraSensors logfiles will not be on the basis of CreationTime but on the basis of LastWriteTime

Version 6.5.0 beta 2 (12/9/2021)

  1. Detection of a CO2 sensor falsly took the CO2 concentration as a double where it must be an integer => corrected, CO2 sensor should no longer be falsly detected (remember Ariane 5 :? ).
  2. The extrasensorsdata.json was searched in the CumulusRealTimeLocation which was not correct, cumulusutils specific datafiles are always in the webroot. => corrected.
  3. Extra sensors are now also detected as NOT PRESENT when their entry in strings.ini is EMPTY

Version 6.5.0 beta 1 (9/9/2021)

  1. AirLink: Clean-up AirLink logs can now be configured through parameter CleanupAirlinkLogs. Only two months of data will be kept when clean-up is active.
  2. Internal/AirLink: the airlinkrealtime.txt is now generated with the rc=y to create the decimal point. For an update you need cumulusutils.js library so do at least one non-thrifty run.
  3. ExtraSensors: Clean-up ExtraSensors logs can now be configured through parameter CleanupExtraSensorslog. Only two months of data will be kept when clean-up is active.
  4. ExtraSensors: Limited beta 1 release of ExtraSensors module.

Version 6.1.2 (2/9/2021)

  1. Bug fix: NOAA - On the first day of a month it does no longer try to display the NOAA report of that month (which caused a failure) but it displays the report of the previous month.
  2. Internal: Reading monthly logs gained roughly 20-30% speed by doing things differently, especially important for long time series and minute sampling stations
  3. Internal: Optimisation of AirlinkLog reader and Dayfile reader
  4. Extra Sensors: Created the possibility to show the Sensor Community map from the Extra menu. The map will be centred on the Latitude/Longitude of the station and displayed on a reasonable zoom level and without the wind layer (see my site for a demo). The user can then zoom in/out and possibly activate the wind layer. No other sensor.community processing is done, the user is repsonsible for actually uploading its sensor data to sensor.community outside CMX environment.

Inifile parameters:

[ExtraSensors]
ExtraSensors=false
ParticipatesSensorCommunity=true

Of which ParticipatesSensorCommunity regulates the menu-item of the sensor.community map and ExtraSensors for the moment has no effect.

Version 6.1.1 (24/8/2021)

  1. Bug fix: Certain information was not in the logfile which made life quite difficult if an error occurred.

Version 6.1.0 (23/8/2021)

  1. All modules: Mentions of inspiration moved to the About/CumulusUtils section of the menu.
  2. All modules: preparatory work for Extra Sensors, only to decide hoew the userinterface will be.
  3. All Charts: The chart container now has a General parameter: ChartContainerHeight=650 giving it a standard height for all chart occurrences. For website users this does not really matter (the default value is what it was) but those who use Graphs and/or the ChartsCompiler as a module will see an effect and they will be able to set the height value to what is wanted for their site. You can remove other (old) occurrences of ChartContainerHeight (may be multiple in other sections) from the inifile.
  4. All Charts: All charts are now boxed with the thin line with curved corner for uniform appearance. This is also valid for modular use and may require slight adjustment of your site.
  5. WindCharts: Added a section to the Wiki on how to deal with the labels for an 8 section weatherstation (default is 16)
  6. RainCharts: Rewrote the calculation for the reference lines of Station Average Yearly Rainfall. Now incomplete years (less than 365 days) do not count.
  7. RainCharts: StdDev range for the station average now can not become less then zero
  8. Maps Wiki: The & (ampersand) character is forbidden in the LocDesc parameter in the section [Station] in Cumulus.ini because it breaks the cgi-bin perl procedure
  9. AirQuality: All references (and internal variable names and (output) file names) with AirQuality have been redone with AirLink to prevent future misunderstanding with Extra Sensors. So: I changed the output file to airlink.txt
  10. Inifle parameter: Changed the inifile section AirQuality to section AirLink. You may want to rename the section to prevent reconfiguration of the AirLink.
  11. Language file: Changed the parameter AirQuality in the section Website to AirLink. NOTE: the section AirQuality in the language file remained the same because it is generic!
  12. Website: Added menu item Extra and moved AirLink (was: AirQuality) to it. This in preparation for Extra Sensor handling

Version 6.0.1 (07/08/2021)

  1. MeteoCam: Added labels for MeteoCam page radio buttons to the Language file (section Website) to be translated by the user
  2. Dashboard: Added Feels Like to the Dew-Gauge
  3. ChartsCompiler: The ALL Plot variable WindSpeed has been modified to HighAvgWindSpeed to prevent conflict with the RECENT WindSpeed variable (See CDL)
  4. ChartsCompiler: Corrected the equations for Psat[....] in the Equations section of the CutilsCharts.def (example in the distribution).
  5. ChartsCompiler: Added the raw pwsFWI charts for RECENT and ALL in the CutilsCharts.def.

NOTE: gauges.js and language.js have changed so you need to copy all i.s.o just the executable and run at least once without thrifty! You may remove the js and css files from the utils directory after this first run to prevent successive redundant uploads.

NOTE: the feels like text(s) in language.js have not been translated for all languages. You may send missing translations by PM and they will be added in future distributions

Version 6.0.0 (21/07/2021)

  1. ChartsCompiler: Finalisation.
  2. Website: Added SolarHours to the Solar text panel
  3. Website: Made the position of the panels user definable (See the new Dashboard Wiki page)

Version 5.6.2 (25/06/2021)

  1. Misc Charts: Fixed bug in counting days in thermal season chart.
  2. Misc Charts: Fixed bug in thermal season chart, it now works correctly on the southern hemisphere. (Tip: use modified thermal boundaries to see useful seasons for your latitude)
  3. Misc Charts: Set the default for Thermal Seasons chart to false
  4. ChartsCompiler: Implemented the POW function (raise a double to some power: POW(number, power). Implemented as Math.pow javascript function
  5. ChartsCompiler: Implemented the SQRT function as Math.sqrt function
  6. ChartsCompiler: Added equations and charts to the CutilsCharts.def
  7. ChartsCompiler: Implemented multiple equation subtitutions e.g. (Avp stands for : Actual Vapour Pressure):
      Psat2008 EVAL [ 6.112 * EXP(17.62*Temperature/(243.12+Temperature)) ]
      Avp Eval [ Humidity / 100 * Psat2008 ]
      AppTemp Eval [ Temperature + 0.33 * Avp - 0.7 * WindSpeed / 3.6 - 4.0 ]

Version 5.6.1 (17/06/2021)

  1. ChartsCompiler: Fixed bug in counting brackets in equations under some conditions.

Version 5.6.0 (13/06/2021)

  1. MeteoCam: First release of a simple MeteoCam (Webcam) module. See Wiki.
  2. ChartsCompiler: Lines starting with a semicolon [;] are now treated as comment.
  3. ChartsCompiler: Equations section added (see wiki for CDL) and they can be substituted in other EVAL equations
  4. ChartsCompiler: EVAL and STATS now work for both the ALL and the RECENT ranges

NOTE: The combination of the EQUATIONS block and the EVAL of PLOT makes it possible to evaluate more complex (as in meteorological) Equations. The Possibility of combining Plotvariables and calculations makes it possible to evaluate different approximations for e.g. Dewpoint. Both clarified by the example below. The release contains as usual a complete set of test charts. Sometimes with meaning, sometimes just for testing. This set of test charts is an example and a test. Nothing more.

Equations
  test1 EVAL [ Humidity/100 * 6.112 ]
  test2 EVAL [ EXP(17.62*Temperature/(243.12+Temperature)) ]
; Documentation:
; https://iridl.ldeo.columbia.edu/dochelp/QA/Basic/dewpoint.html
; Compare the Dewpoint from Cumulus with a calculated approximation
; Later I will enter the Cumulus Calculation and have the Dewpoint be produced by the Davis station
; Nice comparison
;
Chart MyDewpoint Title Dewpoint Calculations in CDL
  Plot RECENT Dewpoint
  Plot RECENT CalcDewpoint EVAL [ Temperature - ((100 - Humidity)/5) ] Axis Temp
;  STATS Dewpoint SMA colour green
EndChart
Chart MyPressure Title Vapour pressure calculations in CDL
  Plot RECENT Pressure
  Plot RECENT MyActualVapourPressure Eval [ test1 * test2 ] Axis Free
EndChart

Version 5.5.2 (06/06/2021)

  1. pwsFWI: the Current pwsFWI button now has forced text colour (not inherited by the background)

Version 5.5.1 (03/06/2021)

  1. Compiler: Value arrays need to be reinitialised when the chart remains open and has its periodic (ftp upload frequency) refresh.
  2. pwsFWI: the Current pwsFWI button moved to the Left Header Text position to improve handling on a portrait held tablet
  3. General: Provided for non-contiguous data series (missing years and/or months).

Version 5.5.0 (29/05/2021)

  1. Distribution: file CUabout.txt has a name change: CUserAbout-example.txt. CUserAbout.txt - if it exists - will be automatically uploaded with the package
  2. Distribution: file CUsermenu.txt will be automatically uploaded if it exists
  3. Distribution: file CUlicense.txt has been removed and replaced by the file LICENSE (with identical content to the website menu choice)
  4. Compiler: Errorhandling of Expression in case of error, now gives an error in the definition of the charts and fallback to the default charts (it was a warning)
  5. Compiler: STATS and PLOT are now handled as equal entry points of the PLOT section of the CHART (see prev version of CDL image to appreciate the difference)
  6. Compiler: a PLOT variable may now have a non-keyword name but if so, it MUST be followed by an equation which contains a valid Plotvariable, if not an error is generated.
  7. Compiler: And if a PLOT has an Eval equation it MUST now have a non-keyword name to prevent confusion and make a unique legend entry (useful for modification or translation)
  8. Compiler: Added the function LN (being the natural logarithm of its argument)
  9. Compiler: Added the function EXP (being the power function with base e)
  10. Compiler: All Plotvariables can be used in one single equation to be combined with operators and functions NOTE: this must be seen as beta function as it is impossible to check all combinations of variables, operators and functions. I don't expect this to work flawlessly although confident. Just play with it and provide me with observations and questions for functionality.
  11. Compiler: The SUM function can only be used once per chart
  12. Wiki: Updates conform development (please notify voids or unclarities)

NOTE:

  1. Because meteo-equations can reach a certain complexity (definitely when written on a single line) a change is considered which should make it possible to use Plotvariables as intermediate calculations or have a definition of partial equations (not plotted) which you might use in Plot. As an example (see the last chart below) One might consider calculating a dewpoint with the Actual Vapour pressure as an intermediate equation.
  2. A second change which is considered is making the EVAL and STATS available for the RECENT parameters as well

However, the side effects of the above may be larger than expected, so it requires some study. In the mean time : have fun!

NOTE: All calculations and array handling in the generated code are totally unsophisticated and non-optimised. This will only change slowly as performance is astonishingly good, beyond expectations, even on my old tablet and phone. Performance reports are welcome.

Below you find three test charts as examples to show what is now possible (the full testset is as always in CutilsCharts-example.def in the distribution and viewable on my site):

 CHART DailyTemp TITLE Temp with statistics offset 5
   PLOT ALL AverageTemp colour pink
   PLOT ALL sumAverageTemp EVAL [ ln(Sum(AverageTemp-5)) ] COLOUR green AXIS DegreeDays
   STATS AverageTemp SMA COLOUR crimson
 EndChart Output Statistics.txt
 CHART DailyRain TITLE Rain with statistics
   PLOT ALL RainFall colour CornflowerBlue as column 
   PLOT ALL sumRainFall EVAL [ exp(ln(SUM( RainFall))) ] COLOUR crimson AXIS Free
   STATS RainFall SMA colour green
 EndChart 
 Chart MyDewPoint Title Dewpoint calculations in CDL
   Plot all minBarometer 
   Plot all maxBarometer
   Plot All ActualVapourPressure Eval [ MinHumidity/100 * 6.112 * EXP(17.62*AverageTemp/(243.12+AverageTemp)) ] Axis Pressure
 EndChart

Version 5.4.0 (21/05/2021))

  1. Language: Create a distinguishable legend in the chart for the columnrange variable (section [Compiler] in CUstringsXX).
  2. Compiler: Implementation of keyword EVAL(uation) of an expression for a PLOT with any weather variable.
  3. Compiler: Implementation of the STATS keyword which will plot a statistic on any weather variable
  4. Compiler: Implementation of the SUM function for the EVAL keyword
  5. Compiler: Implementation of the SMA (Simple Moving Average) statistic as first statistic function.
  6. Compiler: Elaboration of Error messages.

Example code for the EVAL and STATS keywords:

 CHART DailyRain TITLE Rain with statistics
   PLOT ALL RainFall colour CornflowerBlue as column 
   PLOT ALL RainFall EVAL [ SUM( RainFall ) ] COLOUR crimson AXIS Free
   STATS RainFall SMA colour green
 EndChart OUTPUT Statistics.txt

Which results in:

Version 5.3.8 (18/5/2021)

  1. Fix : A fix in errorhandling for a condition which occurs only on Win7 and has been introduced in 5.3.0 or a bit later, h/t @meteo19.

Update is advised!

Version 5.3.7 (15/5/2021)

  1. Misc Charts: Fixed a bug in the titles for the agricultural charts, where the parameters data in the Title were showing fixed values
  2. Maps: Send signature file only once per day (parameter [Maps] DoneToday added)
  3. ChartsCompiler: Added DAILY range specifier (See CDL)
  4. ChartsCompiler: DAILY or ALL charts now have different initial rangeselector: DAILY has 1 month, ALL has 1 year
  5. ChartsCompiler: added columnrange as type for variables which have max and min values (see CDL Graph Types for some implicit semantics)
  6. Added MySQL as a data source alternative to the original datafiles (usage: disadvised and undocumented)

NOTE: In the search for performance improvement and efficiency the MySQL usage has been implemented and experimented with. The conclusion was that MySQL will not serve a better performance in the context of CumulusUtils. I decided to take another route to stay within the the design goals of CumulusUtils.

NOTE: The ColumnRange type specifier was already on the roll and was implemented in the compiler after an idea by @buffaloseven and a technical hint by @beteljuice: H/T!

Example code for the ColumnRange:

CHART DailyTemp TITLE Daily Temperature with ColumnRange
 PLOT DAILY AverageTemp colour green As ColumnRange
 PLOT DAILY AverageTemp colour black As spline
EndChart OUTPUT ColumnRange.txt

Which results in:

Version 5.3.6 (06/05/2021)

  1. Maps: Some users run Cutils output in iframes. Some recent modifications in Maps were not correctly handled in iframes. That has been corrected.
  2. ChartsCompiler: The runtime system now handles click events only for the Home page charts (the click event system will need a bigger overhaul in future)
  3. ChartsCompiler: OUTPUT is now out of beta

Unknown issue: the NOAA reports are not shown on a Samsung tablet but do work elsewhere. Other observations are welcome. An unknown additional click event is generated. Currently looking into.

Version 5.3.5 (02/05/2021)

  1. Charts: bug fix: Agricultural charts now handle few data and no start on January (or July first) correctly
  2. Charts: Agricultural/Seasonal charts now start correctly on July 1 in the southern hemisphere (H/T @mcrossley)
  3. Charts: graphs which are switched off now not only won't be present in the menu but they won't be generated either (reduction of size of the output, time gain)
  4. ChartsCompiler: Output can be defined separately for each chart. See Charts Definition Language and the ChartsCompiler. (bêta for the OUTPUT specifier only)

Version 5.3.3 (27/04/2021)

  1. Charts: added the third Agricultural chart showing the proportional distribution of the thermal seasons over the year (H/T @Pes for the idea).
  2. Website: Added the Wiki-link to the About menu
  3. pwsFWII: Changed the reference for the scientific background to the Wiki
  4. FTP issue: lack of TLS session resumption support in FluenFTP.
  5. The previous point led to a major overhaul of the FTP / Map situation:
  6. => no more regular FTP in the Map module, use is made of a HTTP POST / CGI handling of the signature file
  7. => everybody wanting to use the map can download https://meteo-wagenborgen.nl/maps.txt and include that the normal way in their website (it is done automatically through the software)
  8. => For the normal internal FTP usage, FTP and FTPS protocols remain supported but in case of server issues the only option is to go to SFTP
  9. => Unfortunately the logfile does not accept UTF8 characters so you may get confused, but be assured they are handled well in the Map context

version 5.3.0 (17/04/2021)

  1. Manual: Replaced the README with the Wiki (https://cumuluswiki.org/a/Category:CumulusUtils). All articles are in place. In some foreseeable future the README will get different contents, this is the last release of the manual.
  2. Several review quality modifications as a result of the writing of the Wiki.
  3. Infile parameters: added DoLibraryIncludes to have an unambiguous parameter to determine whether or not to include the highcharts libraries and/or Leaflet library when using e.g. Graphs, Maps and the compiler as a module outside the Website Generator. NOTE: for module users this may have effect on you: CHECK!
  4. ChartsCompiler: Corrected an error in the document load of the compiler output for modular use.
  5. Inet: Changed logging around the FTP connection for all protocols
  6. Enabled the Thrifty qualifier for individual module runs.
  7. AirQuality: removed the helpbutton text when used as a module.
  8. Removed the use of Thrifty for the Map module. Parameter MapsPeriod has no more use (can be removed).

version 5.2.0 (08/04/2021)

  1. Added two growing season graphs (specific for Agriculture): Temperature Sum and Growing Degree Days in the miscellaneous graphs menu. Translations as usual. (suggestion h/t : @Pes)
  2. Unification of the maximum number of visible series when year-series are in a chart (e.g. Monthly Rain). Inifile parameter MaxNrOfSeriesVisibileInGraph is now valid for all charts of this type.
  3. FTPS now uses automatic choosing between Passive and Extended Passive (default when available) mode.
  4. FTPS protocol now accepts SSL 3.0 and TLS 1.0 as well. If any problems arise please let me know.
  5. Some minor bugs and typos.

version 5.1.2 (31/03/2021)

  1. Website: UserAskedData did not serve the AirQuality data under certain conditions
  2. Errorhandling: Added InnerException info in Map for the Upload of the signaturefile
  3. Website: Determine Daylights Saving Time for the station clock no longer requires a non-thrifty run of CumulusUtils.
  4. Map: FTP connection now uses Automatic passive mode (Extended or Standard depending on the server)

version 5.1.1 (23/03/2021)

  1. Website: Fixed a bug for double loading of the first chart
  2. Website: Finished the optimisation of library loading (defer)
  3. Heatmap: Fixed a bug with the All button for larger series

version 5.1.0 (22/03/2021)

  1. Heatmap: Added two more colours for a more dynamic display.
  2. Heatmap: For long series the display is split in pages of 10 years (default but configurable) with buttons Prev/Next and All to walk through the pages.
  3. ChartsCompiler: The Solar axis when used for only the radiation now has a scale fixed to the current theoretical solar maximum. The image therefore does not easily change.
  4. ChartsCompiler: added RECENT and ALL qualifiers for the Plot variables. Updated the definition specification. Option for the legacy DAILY charts is available but not now implemented.
  5. ChartsCompiler: Added HeatingDegreeDays, CoolingDegreeDays and EvapoTranspiration as Plot variables.
  6. ChartsCompiler: Added yAxis for DegreeDays and Evapotranspiration.
  7. ChartsCompiler: Added the infrastructure to add JSON data if CMX does not provide (like e.g. the Evapotranspiration).
  8. UserAskedData: Commandline parameter UserAskedData provides the JSONs for non provided data and encompasses missing weather data and AQ data (the old AirQuality Thrifty handling is now obsolete).
  9. Dayfile: Modified for additional parameters and global handling of the list.
  10. Monthfiles: Modified to read only one or two files to create a list for the subselection for the RECENT graphs (evapotranspiration and maybe other possibilities).
  11. Monthfiles: Addition of inifile parameter MonthsOfMiracleAndWonder. If CumulusUtils uses a Locale other than that of CMX the filenames for the monthly logfiles are formed differently. In case of trouble edit this string to create CMX matching filenames.
  12. Website: Moved to jQuery 3.6.0

version 5.0.4 (09/03/2021)

  1. AirQuality: patch release to account for a build error.

version 5.0.3 (07/03/2021)

  1. AirQuality: bug fix concerning the windbarbs in relation to the renewed unit handling (as introduced in 4.10.5).
  2. Graphs: Fixed a bug in the heatmap where a zigzag blue line was visible (sometimes in front, sometimes in back).
  3. Graphs: Added the HighchartsDefaults and HighchartsLanguage as the includes when graphs used as modules. NOTE: this will modify the look and feel of the graphs slightly, especially the axis.
  4. Internal: Review of all ajax calls.
  5. NOTE: when using graphs as a module, users can modify the height of the Graphs container by specifying in a style section of their template: #chartcontainer {min-height: 620px;}

version 5.0.2 (04/03/2021)

  1. WindGraphs: Acceleration of the WindRose creation by 35%
  2. WindGraphs: For 8 sector wind direction stations (e.g. Fine Offset) this is now also reflected in the WindRose.
  3. HTML: Added deblocking and deferring actions to speed up index.HTML
  4. Charts: bug fix for the Home charts: the default chart and the fall back every 10 minutes are now correct.
  5. Charts: Click events defined in the user definitions of the charts are now handled correctly.

version 5.0.1 (01/03/2021)

  1. Bug fix in Charts Compiler: Numbers in the Charts definitions are obligatory with a decimal point and not a free to use decimal locale separator. So the whole compiler and code generation now function under the Invariant Locale having the point as decimal separator.
  2. Barometer scales are now set to the stations min/max records to get the effect of a real barometer without you requiring to adapt for the ever changing scale.

version 5.0.0 (28/02/2021)

  1. FTPS: Release
  2. Graphs: Added the Charts Compiler - Release.
  3. See the separate document in the distribution.
  4. General: bug fix - unit for mile is mi and not mph
  5. General: Upgraded the Bootstrap base version to 4.5.2

version 4.10.6 (20/02/2021)

  1. FTPS: Fixed a bug where the port was not assigned when using FTPS
  2. Added SFTP access.
  3. Internal: Added the Pressure in the Month file List and made the list sorted on date (no direct effect for user).
  4. Internal: Made first steps to use MySQL/MariaDB as data source.
  5. Graphs: Added the Charts Compiler in zeta release (meaning it is there but you won't notice unless you really want to look at it). See my separate post.

version 4.10.5 (14/01/2021)

  1. Map: when using the map as a module it was lacking the jQuery library include. That is fixed now. Has been published before as 4.10.3 patch1
  2. Internal: Redesign and rewrite of the unit handling and conversion possibilities (when required). One of the first foundations of CumulusUtils I wrote at the start of Top10 and pwsFWI. However I got more and more annoyed by the way I handled it so I changed it from an aesthetic and a technical point of view. It has been tested but as you can imagine not all permutations have been handled, so keep an eye open and please report bugs. Especially when you use units other than km/h, °C, hPa and mm.
  3. Several smaller changes internal and in UI.

version 4.10.2 (05/01/2021)

  1. Website: Added some runtime logging for verification purposes only.
  2. AirQuality: fixed a bug where the realtime values contained a comma because of the locale, which was not changed to a point when required.
  3. AirQuality: Added optional Windbarbs to the Air Quality graphs (really great :D See meteo-wagenborgen for demo).

version 4.10.1 (01/01/2021)

AirQuality: xy zooming now works on a tablet too.

  1. Map: applied some 'beteljuice changes' to the map.
  2. General: made the first run for First Time Users more accessible and easier to understand. Console output is now default true at first run.
  3. Fixed a fatal bug in formatting the filename of the AirLink logfile.

version 4.10.0 (28/12/2020)

  1. Map: Reintroduced the Map module in CumulusUtils. Completely overhauled and rewritten. No command but an inifile parameter (Participant) governs a station to be on/off the map.
  2. AirQuality: Decided on the reference lines / Help button. EU-CAQI one hour series will act as reference line for all as explained in the text under the help button.
  3. AirQuality: Graphs now have xy scaling.
  4. FTP: Modified the FTP module such that if a user does not use FTP and even does not have it defined on its system, CumulusUtils will always continue and generate the output.
  5. Technical: various clean-ups and modifications in the Javascript runtime system.

version 4.9.0 (18/12/2020)

  1. AirQuality: Modified CA and AU AQI translation to the table view in the path to perfection.
  2. Removed the Map module completely from CumulusUtils.

version 4.8.4 (16/12/2020)

  1. Website: Added Day length at solar info.
  2. Website: fixed erroneous 'correction' of time and date separators in the javascript runtime for the dashboard.
  3. AirQuality: graphs are now drawn with spline.
  4. General: Now parameter NormalMessageToConsole also works on Windows.
  5. General: changed the level of several messages (INFO became ERROR; WARNING became INFO and INFO became VERBOSE etc...). In general will the visual appearance of the logging have changed so don't be surprised.
  6. General: If a timeout occurs in the FTP Upload procedure a stackdump originated. That has been corrected and should now be just an error.
  7. General: Improved error handling to prevent stackdumps (especially around FTP). This will be an ongoing exercise no doubt. The new FTP lib apparently demands different handling.

I can use feedback on messaging.

version 4.8.3 (9/12/2020)

  1. Patch for repair of fixed IP for development to localhost for communications with CMX.

version 4.8.2 (9/12/2020)

  1. General/Technical: Logging has been rewritten. Verbosity level can be controlled (None, Error, Warning, Info and Verbose) and messages are subdivided in those types.
  2. General/Technical: Progress messages can be written to the console.
  3. Technical: Age of the FTP lock file is now correctly determined outside the CET time zone.

version 4.8.1 (4/12/2020)

  1. AirQuality: Bugfix in JSON datafile creation when the CMX parameter DataLogInterval is larger than one minute.
  2. PwsFWI: On request of a lot of users the Current Value now has the possibility to be set to Today's value (when using prediction). See the parameter section of pwsFWI for CurrentIndexDay (possible values: Yesterday (default), Today)

version 4.8.0 (1/12/2020)

  1. Added graphing for the two AirLink sensors.

version 4.7.2 (24/11/2020)

  1. Parameter SslFtp did not exist in Cumulus 1; Made sure the default is correct on C1 / Win7 machines.
  2. Made sure FTP logging works on Win7 machines.
  3. Made sure Maps works on Win7 machines

version 4.7.1 (20/11/2020)

  1. Manual: Further fine tuning info UploadDir and CumulusRealTimeLocation.
  2. Technical: Reported issue to FluentFTP with respect to FTPS. Waiting for feedback/Solution. As a workaround downgrading the FluentFTP library to 32.3.1.0. works. It will remain so until certain upgrade is safe.
  3. Technical: Optimised some parts of the CumulusUtils javascript runtime.
  4. Technical: resolved a naming conflict between CumulusUtils and a library. The effect of this conflict is unknown, but it may account for some weird effects some users encountered.
  5. AirQuality: Bug fix adjustment decimal separator.
  6. AirQuality: When using thrifty, the module is not uploaded (not necessary because the info seen is realtime, no history data so far, this may change in future).
  7. AirQuality: The calculation of the AQI has been fine tuned and should be OK now both in CMX (build 3097) and CumulusUtils.
  8. AirQuality: The table width of AirQuality report must fit within its frame.
  9. Maps: The lockfile mechanisme has now been rewritten to take advantage of the FluentFTP library. The algorithm did not change, the use of FTP did. Keep an eye open for anomalies.

Version 4.7.0 (15/11/2020)(Withdrawn)

  1. Run: the executable and dlls have been removed from the CumulusMX directory to the utils\bin directory. You have to call CumulusUtils with the following command (being in the cumulus directory) utils\bin\cumulusutils.exe. This avoids conflict and synchronisation of version of dlls. Cumulusutils has now evolved into technical independency.
  2. Internal FTP: Made FTPS available (SFTP will follow);
  3. Internal FTP: Made FTP logging optional (section [FTP site], parameter FtpLog, default off)
  4. Map: Internal working has changed because the Map database stationswithutils.xml underwent a provider change because of the FTP changes.
  5. Technical: CumulusUtils is now using ServiceStack.Text.dll i.s.o. NewtonSoft.Json.dll (You may now remove Newtonsoft dll from the CumulusMX directory is you are on CMX version 3.9.1 and higher)
  6. Added a NOTE at the start of the manual to focus on the parameters CumulusRealTimeLocation and UploadDir to avoid confusion.

version 4.6.3 (11/11/2020)

  1. Maps: Reverted to old FTP system (only plain FTP supported) and corrected for provider change of Map database.

version 4.6.2 (6/11/2020)

  1. Website/AirQuality: Realtime files and general report files (like pwsFWI or YADR) are now read with the cache=false qualifier in the ajax call. This should improve user experience.
  2. AirQuality: reworked the interface for the order of the first columns.
  3. AirQuality: Fixed a bug concerning the normalisation of the AQI to the position of the indicator on the right panel of the table.
  4. AirQuality: Changed default country to US.

version 4.6.1 (4/11/2020)

  1. Website/AirQuality: If no sensor is present, the menu choice 'AirQuality' will not appear in the menu.
  2. AirQuality: The CA handling of the AQI is debatable and in my view incorrect. The AQI display will for the time being be like the US en needs to be set accordingly in CMX.
  3. AirQuality: Fixed a bug when generating the outside sensor. Both in the sensor code as in the airlinkrealtime.txt file (a space too many was generated).

version 4.6.0 (3/11/2020)

  1. Sysinfo: For the Raspberry Pi the CPU temp is now available.
  2. Air Quality: The first release of the Air Quality module, support for the Davis AirLink sensor and my own FakeAirLink system. Version 4.6 may be regarded as a beta to the AirQuality system as many things have to be optimised and maybe even rewritten. It is working fine though.

version 4.5.5 (26/10/2020)

  1. Website: Fixed bug for DST switch. Station time now is correct.
  2. Monthly logfiles: Fixed bug for existence of AirLink logfiles. Now they are ignored.

version 4.5.4 (4/10/2020)

  1. PwsFWI: Fixed bug for Current PwsFWI value on the menu bar.

version 4.5.3 (3/10/2020)

  1. Now all HTML of the individual modules are W3C Validator compatible (which includes some technical changes which I think have no impact |) ).
  2. Added the start of observation date to the record pages.

version 4.5.2 (2/10/2020)

  1. NOAA: Fixed a bug which generated a new file only the 2 day of the year i.s.o. the second day of the month when under thrifty.
  2. Website: Fixed the last HTML errors on the main site but you won't notice. The website generator is now W3C Validator compatible and should not generate errors.
  3. Website: If Google-Analytics is enabled (an ID is defined in GoogleStatsId) it is now possible to give the user (or just yourself) an opt-out possibility (PermitGoogleOptout=true), see the manual.
  4. Solar and UV are now separately configurable both for both dashboards.
  5. It is now a requirement for use of cutils as a module provider, to use UTF8 character encoding of the page the module is used in. Specifically for the character for degrees and other characters outside the standard range like all language specific characters (the website generator has this standard automatically).

version 4.5.1 (24/9/2020)

  1. Solar Graphs: Y-axis description changed from “Daily kilo Watt hour” to “Daily kilo Watt hour per m2”. Note that this is only the default, you have to change your translation yourself.
  2. Website: Finally fixed some HTML errors on the main site but you won't notice.
  3. Maps: Both the user map and the Station map now will always fit within the report view and will be responsive on other devices. The height of both maps is fixed to 750px.
  4. Stationmap: the zoomControl has been removed and scrollWheelZoom has been disabled. Effectively it has become a station map with zoom fixed to the setup used at generation time.
  5. Forecast SpotWx, Wxsim forecast both now have a 100% width and should be responsive. This does not work well on the Norwegian forecast so that one remains fixed 1000px. Wxsim has not been tested because I don't have it. Please be aware and report back if you need change to keep the result within the report view.
  6. UserMenu: If you wish to use an iframe to start up more complex URLs in the report view, I would advise to use “width='100%' frameborder='0' style='border: 0; height: 75vh;'”.
  7. This should keep this within report view limits on all devices (not saying it is useful on all devices). I could not get it to work on Effis though. Wxcharts does not do well on the multi plot view. For images please use “width='100%' height='100%'”

version 4.5.0 (23/9/2020)

  1. No functional changes just the version number and some additional code optimisations.

version 4.5.0 beta2 (22/9/2020)

  1. Bug fix for correct reading of older records (Solar radiation was introduced in version 1.8.5 and Current theoretical max solar radiation in version 1.9.1. Old logfiles do exist in the wild.
  2. Bug fix for variable interval.
  3. Additional logging for solar graphs wrt the variable interval.
  4. Performance improvement on the creation of the solar graphs wrt the determination of the variable interval.
  5. Number of error messages per datafile are maximised, currently at 10.
  6. Some minor changes to texts and default values of texts.

version 4.5.0 beta (20/9/2020)

  1. Addition of Solar graphs (Solar Hours and Solar Energy).

version 4.4.1 (13/9/2020)

  1. Station Map: bug fix for initialisation.
  2. Station Map: Added Beaufort in text below the wind arrow.
  3. Station Map: Map now centres between wind arrow and station marker.
  4. Three compass roses are now in distribution, no 1 being the default.
  5. One arrow now in distribution, no 1 being the default.
  6. Users can add compass roses and arrows at will. Naming convention in the manual.
  7. Manual – continuous work in progress - is reworked for the parameters which are now part of their functional section. All parameters should now be documented.

version 4.4.0 (11/9/2020)

  1. pwsFWI: removed “NOTE: Behavioural testing still under way!”. De module is now seen as correct and finished after a year of testing against field observations and EFFIS. Thanks to all who participated as early adopters (the first 15 you find here).
  2. Website: If all graphs of a group are switched off the corresponding menu won't appear in the main page.
  3. Station Map module is introduced (though not a real module because it can't function without the 'realtime' system). Run 'cumulusutils.exe website' without thrifty. See manual.
  4. Menu choice for Station Map is configurable
  5. Graphs: The colours contained a bug where it was not possible to empty the parameters GraphColors and WindRoseColors.
  6. Graphs: minor changes/improvements
  7. Thrifty: minor changes/improvements
  8. Prepared the monthfile records for use in other graph modules.
  9. Manual – continuous work in progress - is reworked for the thrifty system with focus on graphs.

version 4.3.1 (7/9/2020)

  1. GraphWind: Windrun Graph title now has AllTime (section General) text i.s.o. Year 0.
  2. Where distance is used as unit with the WindRun display (graph, YADR etc...), now the correct distance unit is displayed: km for km/h; km for m/s; mi for Mph; nm for Kts (as the Wiki says)
  3. GraphsWind and YADR: The class width for WindRun is now configurable (default 75) through inifile parameter: WindrunClassWidth (section: Graphs).
  4. NOAA: the report page may now start in the current month or in the current year. This can be configured therough parameter StartInCurrentMonth in section [NOAA].
  5. All modules: Checked for UTF8 output and corrected if necessary. Now all files are guaranteed UTF8 written.
  6. Restored the double quotes in the language string for CompasSectors which had been erroneously modified in version 4.1.0. This is only important for new users where the inifile parameters are initialised.
  7. Modified/added some logging messages.
  8. Some [minor] code corrections/cleanup.

version 4.3.0 (3/9/2020)

  1. Website: Modified the menu to accommodate separation of graphs from reports.
  2. Top10: Added total wind run per day.
  3. YADR: Added total wind run per day.
  4. YADR: Pression now give high and low values of the barometer
  5. Graphs: Changed the default colour scheme for the graphs with configurable colours (within the application). The HighchartsDefaults remains untouched. To try, comment out or remove the parameter GraphColors (take care if you modified colours yourself!).
  6. Graphs: Modified the module construction such that Wind graphing was added, currently consisting of the WindRose (which was deleted from Miscellaneous Menu) and a WindRun statistics graph.
  7. WindRose: the WindRose is no longer a separate module but belongs to the WindGraphs.
  8. Graphs: now partitioned into four submodules (which cannot be separately generated but which graphs can be switched off)
  9. Graphs: Thrifty component for Windrose has been removed. The WindRose now follows the Windgraph thrifty periodicity. If you wish to speed up generation for experimentation you can still set WindRose to false.
  10. Bug fix: Forecast – The Latitude and Longitude do not have a consistent format in Cumulus.ini. Sometimes it is three or four digits, sometimes it is 8 digits or more. Handling the coordinates as a string to be used directly to the URL of SpotWx with four digits failed causing a crash.
  11. This has been fixed.
  12. NOTE: The Windrun and other modules work for the units as defined in CumulusMX. Only for in some situations conversions must be applied. If you encounter such situation please let me know. So far no imperial unit installations have been tried. For the Windrun I don't know what the run distance is taken in if the windspeed is m/s. I assume km.
  13. Continued work on research of this Mono Error. So far no result. I appreciate any observation report. If it occurs on your system you will find files with a name like mono_crash.0.0.json in your cumulus directory. So far it does not seem to be damaging and everything seems to function as it should.

version 4.2.4 (26/8/2020)

  1. Adjusted the file read procedures to accommodate the new internal data format of CMX (to be released later).
  2. Forecast: The SpotWx has a Timezone component. The naming is different on Windows and Unix/Linux which is not understood by SpotWx. I therefore changed the timezone to the simple numeric representation of hours. It should now work everywhere.

version 4.2.3 (24/8/2020)

  1. Forecast: Added SpotWx as default Forecast system.
  2. Language: Added a language tag for WindRose – PeriodInWindRose (section Graphs) which is for the title of the period legend added in v 4.1.0. Note that I repeat the related release note of v 4.1.0: Language: Moved the words Year and Month from section Website to the General section (so in your language file make the same move and you're good).
  3. PwsFWI/Website: Made the pwsFWI current file configurable for the Betel-Kocher gadget (see manual pwsFWI).

version 4.2.2 (21/8/2020)

  1. Graphs: Fix for a HighCharts [library] modification which takes care of negative values on logarithmic scales (used in the Rain Graphs). This stopped working some days ago, with this version it is repaired.
  2. Tech: await now used on Forecasts.
  3. Some minor code corrections.

version 4.2.1 (18/8/2020)

  1. Fix for a bug which failed under some conditions to get Webtags for SysInfo and for Inifile parameters.

version 4.2.0 (18/8/2020)

  1. The module UserReports is now alpha.
  2. Graphs: Rain and Temperature Year/Month statistics graphs now start in the current month (that is the month in which the graphs were generated)
  3. NOAA: Adjusted NOAA report Width to 700 to avoid horizontal scroll bar.
  4. Language: Swedish sv-SE made available.
  5. Improved Usage message.
  6. Tech: Finalised / cleanup code changes for async/await and HttpClient.

version 4.2.0 beta (13/8/2020)

  1. Changed Norwegian from NO (which is not a language code, but a country code) to NB (Norsk bokmål) and NN (Nynorsk). This had already been effective in 4.0.0, but with the completion of language.js for the gauges and the publication of the translations on the Forum on 10/8 it is now a formal change (by sutne/Steinar, thnx)
  2. Added Webtag processing for inifile parameters.
  3. Added UserReports with Webtag processing, see the manual.
  4. Tech: reshuffle the HttpClient/internet code. This introduced also async/await processing and more or less threw some thing upside down. Therefore this release is done as a beta. If you experience issues, please notify me and fall back to the 4.1.0 release which you no doubt saved.
  5. Having said that I think the release is good enough and you are invited to play with the added webtag features.

version 4.1.0 (8/8/2020)

  1. Fix for some minor glitches, the first of it was released as version 4.0.1 (unregistered version).
  2. Website: Complete overhaul of the Skin/Theming options and system for the CMXgraphs to facilitate modification of the Dark theme (and probably also other themes) of Highcharts.
    1. Themes (included the principal default) added in distribution for the user to start modifying.
    2. Manual: complete and extensive rewrite of the chapter on Skin/Theme and HowTo. NOTE: any legal color format can be given in both the cumulusutils.ini and the HighchartsDefaults.js. This includes the transparency field.
    3. For the normal reporting in the ReportView, the colours are basically ruled by the parameters ColorReportviewText, ColorReportviewBackground, ColorReportviewTableData. This hold too for report subscripts. For possible links, format is taken from the footer: ColorFooterLink, ColorFooterLinkHover.
    4. Some changes in behaviour of the graphs for the default theme.
  3. PwsFWI: changed the color of the text Legend. It now obeys ColorReportviewText.
  4. Website/All: Fixed a bug where the graphs module was always generated under Thrifty condition (meaning sometimes they were not generated when that was intended even when CU was run only with graphs as argument).
  5. Website: The header is split in three parts. Center is the title and the location for 60%. Right and left have 20% and is governed by the inifile parameters HeaderRightText and HeaderLeftText.
  6. WindRose: As the WindRose has no time axis, the graph itself needed an indicator so a print would have a period indicator on it. The text colour of the period legend (let's give it a name) will always be the same as the Title color of the graph (which is rules by the theme)
  7. Language: Moved the words Year and Month from section Website to the General section (so in your language file make the same move and your good).
  8. PwsFWI: fixed a bug where, with less than 35 records in dayfile; Analysis on 30; and without prediction, the module crashed.
  9. Graphs: fixed a bug where, when the nr of periods for the moving average is less then the figure defined in the inifile, the data-section of the Highcharts graph code for the moving average, missed an opening '['.

version 4.0.0 (29/7/2020)

  1. This update touches most core files so please run a full update and upload all delivered files (to the lib and css library).
  2. General: Adapted CumulusUtils to take advantage of CMX 3.7.0.
  3. General: The consequences of the technical rift are described in the chapter Before and after version 4.0.0 of this manual.
  4. General: The biggest difference is that CMX MUST be running when CumulusUtils is activated. If not, Utils will run to completion but some information will not be available.
  5. SysInfo: The systeminfoTable.txt file no longer needs to be processed by Cumulus and its entry in 'Extra Webfiles' can be removed. It is now a module like any other.
  6. Website : The version information in the footer now shows information when a new CMX version is available.
  7. Website/Home : The CMX graphs are upgraded to the level of CMX 3.7.0 and now display conform the technique offered by CMX. This means that the lines displayed are defined in CMX and no longer in CumulusUtils causing the data not to be send if the parameter is switched off.
  8. Website/Home : If the inside Temp/Hum is activated in CMX, it still can be deactivated in CumulusUtils (though the data will be send)
  9. Website/Home: Daily temperatures now are smooth lines.
  10. Website/Home: The user can choose between lineWidth 1 or 2 through parameter HomeGraphLineWidth. The value holds for all graphs.

version 3.9.11 (26/7/2020)

  1. Website: Modified colouring of the ReportView to accommodate the Dark Themes:
    1. NOAA now have their own colour parameters – ColorNOAAText (def: Black) and ColorNOAABackground (def: #f9f8EB)
    2. To make the YADR table data independent because of the intrinsic colouring a new parameter has been introduced – ColorReportviewTableData
    3. To make the Beteljuice format for pwsFWI workable in the dark theme, the website now uses the text colour of the ReportView as text colour for the legend and the key
    4. The System Info now adheres to the ReportView background and text colours.
    5. Any subscript to reports (as HTML paragraphs) now adhere to the ReportView background and text colours. The links and hover definitions adheres to those of the footer.
  2. Map : A lockfile will expire after three minutes after which it will be regarded as orphaned and removed. Deadlocks because of orphaned lockfiles should no longer occur.
  3. Checked against CMX 3.7.0 – minor glitches, no issues.

version 3.9.10 (22/7/2020)

  1. Technical: Modification of the function for reading of XML data to counter a technical issue.
  2. Technical: Preparation for version 3.7.0 of CMX.
  3. Website: Added inifile parameter SiteTitleAddition in section [Website], default: empty string.
  4. Thrifty : If yesterday rain detected, graphs are always generated.
  5. Thrifty : Finalised and perfected the logic.
  6. General : For the Norwegian language the code NO is removed as accepted language and nn-NO and nb-NO are added.
  7. General : language.js (for the gauges) has now been adapted for the two official Norwegian languages: Nynorsk (nn) and Bokmål (nb).

version 3.9.7 (12/7/2020)

  1. Website / All: First step - optimized the Thrifty logic.
  2. Maps: Fixed bug in clean-up segment where an empty map was produced.

version 3.9.5 (4/7/2020)

  1. Website: The HTML LANG now really contains the locale.
  2. Map: In the battle against the random errors in the stationswithutils.xml data file, an FTP lockfile mechanism has been implemented. Now one and only one station gets access to that file. Other stations wait at most 8 seconds, if they don't get the lock, the Map generation is abandoned for this run (and if that happens often, the user is advised to use a less occupied time slot).
  3. Sysinfo: The report width is now configurable (Default is 700px)
  4. Sysinfo: Windows users can configure lines not to display. Run the command systeminfo and count the lines. Host Name is line nr 1. Fill in the section [SysInfo], for parameter SystemInfoLinesToSkip with comma separated line numbers e.g.: 7,10,11,20 That's it.
  5. Dashboard: Slightly tidied up in the sense that line breaks between the figure and the unit are prevented.

version 3.9.3 (27/6/2020)

  1. SysInfo: On windows the listing now stops when the line with pagefile.sys (excluded) is found. This should be valid for all languages. The listing now is left aligned with width: 700px, centered in the ReportView.
  2. Website: To increase consistency, the HTML LANG will contain the locale from the inifile (Read this and this). This will better satisfy search engines.
  3. Website: Clicking a gauge or text block in the dashboards, loads the corresponding graph into the ReportView.
  4. Made a message on the forum and an entry in the manual to draw attention to the possibility of changing the graphs appearance through a theme to complete user modification of CumulusUtils. (using this technique btw also holds for the modules and for CumulusMX itself).

version 3.9.2 (23/6/2020)

  1. Graphs/Website: Implemented the UseHighchartsBoostModule inifile parameter to enable/disable the Highcharts boost module. This to bypass a problem with Google Chrome and/or certain graphics cards. Note: You can also switching off the hardware acceleration of Chrome iso setting this to false!
  2. Small correction in Maps for Lat/Lon with comma in it (they will now show on the map)

version 3.9.1 (22/6/2020)

  1. Maps: Made Name, Website and Latitude/Longitude compulsory for website registration (and therefore for use of Website generator).
  2. Maps: If an entry is not updated within 7 days it is removed from the map (Cleanup).
  3. Graphs: Changed to the latest stable, made some minor corrections.
  4. Graphs: Included the boost module as a result of this discussion. This dramatically increases performance.
  5. General: Fix for a possible interference with the Cumulus inifile read/write.

version 3.9.0 (20/6/2020)

  1. WindRose: inverse of stacked display/legend now ruled by parameter WindRoseInversed: true/false, default false.
  2. Website: Overhauled the switching system of the dashboard. Although no functional change and even small technical change, this is a major improvement (with a little help from Mark).
  3. Dashboard: Instead of the ledVisible parameter which was removed in version 3.8.3, there are now thresholds which – if activated - trigger the led for that specific gauge. See the manual for description. Run once to make the parameters appear, fill in and run again.
  4. Any error in the locale/language given in the inifile now no longer aborts CumulusUtils, but sets it default to en-GB.
  5. Manual: NOTE – just below the TOC – on performance during update because of WindRose.
  6. General: Cumulus.ini is no longer read directly but a copy is made and afterwards deleted because of some suspected interference.
  7. Known issues: Several anomalies – Causes unknown and will be researched. This will be addressed later.
  8. if the threshold value is higher than the max value shown on the gauge, it is unpredictable which value it takes (specifically relevant for the wind gauge).
  9. For the rain gauge there is no indicator which value is set. If the value is higer than set, the led should start flashing. The ThresholdRainVisible parameter is used to enable the led.

version 3.8.4 (15/6/2020)

  1. YADR: Nr of rain days in the rain summary table now actually displays the nr of rain days.

version 3.8.3 (15/6/2020)

  1. NOAA: corrected the Thrifty generation method for the 2d day of the month iso 2d day of the year.
  2. Dashboard: Moved UTC down in Clock section.
  3. WindRose: Reversed the legend for the WindRose: low to high wind speeds will be listed top/down.
  4. Website: If the site remains open in the Home situation (The Cumulus Graphs reportview) it will refresh the graphs on the interval the user has defined in the CumulusMX inifile [FTP site] section, for parameter UpdateInterval. The timer for this action restarts if within the priod another report is viewed.
  5. Dashboard: Because of oscillations of the gauge needle around old and new values, the inifile parameter SteelseriesLedVisible now defaults to false and has been removed from the CumulusUtils parameter set. You may remove it from the inifile. If, in future, the problems around this parameter have been resolved, it may be reintroduced for use within CumulusUtils.
  6. DayRecords: Changed selection for formatting. Only noticable for users with less than two years of data (but you never know).
  7. DayRecords: Fixed the formatting for the HighGust column (which was missing, nobody noticed :) ).
  8. YADR: changed table fonts to 80% and normal (not bold) to accommodate smaller PC and tablet screens. Comments are welcome.
  9. Some code optimizations.

version 3.8.2 (6/6/2020)

  1. DayRecords: improved/corrected the Thrifty generation method.
  2. Top10Records: improved/corrected the Thrifty generation method.
  3. Site Stats: For the google statistics, now for the ReportViews event-statistics are gathered as well. More useful than page stats because it is only one page :)
  4. Some code optimizations.

version 3.8.1 (4/6/2020)

  1. Records: improved/corrected the Thrifty generation method.
  2. Logging: improved messages.
  3. General: using locale definitions for the two letter ISO language code (if it were only for the differences between en_GB, en_AU and en_US). IMPORTANT: Please read the NOTE on locales and Language parameter at the start of the manual!
  4. General: Language must exist as gauges translation. If not CumulusUtils exits.

version 3.8.0 (02/6/2020)

  1. Dashboard/Website: full parameter checking and verification before using the user settings. Messages are created when errors are detected. In case of invalid, setting parameter defaults.

version 3.7.5 (01/6/2020)

  1. Move log-directory to utils directory to prevent pollution of the CMX directory.
  2. Several minor code optimizations and changes which should go unnoticed. Some changes in logging for clarification, removal of erroneous messages.
  3. Manual: Updated the manual on the thrifty system general.
  4. Manual: Updated the manual on the thrifty system specifically for Yadr, NOAA, Records and DayRecords.
  5. Manual: added the modifying parameter values for the gauges.
  6. Manual: added the WindRose (had already been done partially in previous versions) and updated/corrected the whole thing a bit.
  7. Thrifty: Yadr now only generates and uploads the data files for the current year, the menu file only on 2 January of the current year (so the generation is now omitted as well).
  8. Thrifty: NOAA reader now only generated and uploaded on 2 January (Note: the data files are generated by CMX itself).
  9. Thrifty: Records is now only generated when a Yesterday record occurred.
  10. Thrifty: Graphs are now generated every 7th day from January 1 (so actually (DayOfYear MOD 7 == 0). Looking for a more sophisticated decision.
  11. Advise: For the website generator: run daily under Thrifty system.
  12. pwsFWI: Relative Humidity in the table is again displayed with an accuracy of two digits.

version 3.7.3 (30/5/2020)

  1. Dashboard: Added some configuration parameters for the gauges
  2. Thrifty system: fine tuned the top10 thrifty system
  3. Thrifty system: DayRecords dirty-bit system is now working so under the thrifty system, if – and only if – yesterday had a record, the file is written and uploaded.
  4. Modified manual (I would appreciate feedback if erroneous or incomplete).

Version 3.7.2 (29/5/2020 – not public)

  1. Dashboard: Added some configuration parameters for the gauges

version 3.7.1 (29/5/2020)

  1. pwsFWI: If both the Title and the SubTitle entries in the Language file are empty then no (empty) lines are produced.
  2. All logfiles are now to be found in the directory utilslog and they will have the name: yyMMddHHmmcumulusutils.log (sorts easily alphabetically) So that would be e.g. 2005271332cumulusutils.log. Logs will be kept for 2 days. This gives the possibility to run CumulusUtils many times per day (e.g. every 10 minutes for SystemInfo) and if you find a problem later in one of the major runs at midnight, you still have that log.
  3. Dashboard: changing the appearance of the gauges should now work.

version 3.7.0 (27/5/2020)

  1. Forecast: Added WXSIM as forecast system, see manual how to do it, please notify if additional possibilities exist.
  2. CheckOnly: increased performance by removing redundant writing to logfile. Now only markings and real error situations are logged.
  3. Dashboard: Colour of Up/Down-indicators for Temperature and Pressure now have their own parameters: ColorDashboardUpIndicator and ColorDashboardDownIndicator.
  4. NOAA: Year selection through drop down now adjusts months selectable.
  5. Dashboard Gauges: Gauges are now modifiable through the inifile parameters. See website inifile parameters.

version 3.6.9 (25/5/2020)

  1. Bugfixes for WindRose (accommodate a single quote in the subtitle, add a semicolon, remove comma at end of data)
  2. Changed Dashboard 1, Wind to better accommodate Latest winds, Average and Beaufort. Beaufort is now related to Average wind, not Latest measurement.
  3. pwsFWI: put a title on the report page to provide more clarity for newcomers to what they are actually seeing.

Version 3.6.8 (24/5/2020) – patch release for debugging.

version 3.6.7 (24/5/2020)

  1. Dashboard: In dashboard 1, now the Beaufort scale is shown in the Wind block with same background colour as defined in the YADR Wind module. Note that the wind speed / Beaufort shown is the latest wind speed reading (equivalent webtag: #wlatest)
  2. Thrifty: Under the thrifty system, the WindRose is only generated when upload is scheduled (second day of the month).
  3. Thrifty: Under the thrifty system, top10 is only generated (!) and uploaded when there is actually a new record (the file is 'dirty'). Only Yesterday is checked so a daily run is assumed.
  4. Thrifty: Under the Thrifty system, YADR only uploads the current year.
  5. PwsFWI: Added pwsFWI to the NAV-bar, just beside the LED. Click leads to the report. In the process, moved the current value to the ini-file as well. The pwsFWIcurrent.txt remains (same contents).
  6. pwsFWI: changed nr of decimals from 2 to 1. For the Beteljuice interface, made the borders round corners again under the Bootstrap system.
  7. CheckOnly: Added Monthly Logs to the CheckOnly command.

version 3.6.6 (22/5/2020)

  1. WindRose: the ZeroWind percentage is now shown for each period selected.
  2. WindRose: added footer when used as module.
  3. Monthly Logs: added extensive Exception handling to accommodate historical increasing record length (in relation to fields required)

version 3.6.5 (19/5/2020)

  1. General: Added the Thrifty qualifier for Website and All commandline parameters to economize on bandwidth (for subscription and mobile users). Description in the manual.
  2. WindRose: Added a check for data consistency concerning the internal data separators (governed by the locale). If any inconsistency is found an error message is written to the logfile, CumulusUtils exits and the user has to clean up the data directory.
  3. WindRose: Bugfix concerning the filelist of the monthly log files.
  4. WindRose: changed the Y-scale from fractions to percentage.
  5. Made some modifications to the manual for clarity.
  6. Created a section [General] in the CUstrings[xx].ini files. Some strings may move there requiring you to move the translation as well. I will try to minimize the translation effects but while in development phase it may be inevitable. I apologize beforehand.

version 3.6.2 (19/5/2020)

  1. WindRose: Added a check for data consistency concerning the internal data separators (governed by the locale). If any inconsistency is found an error message is written to the logfile, CumulusUtils exits and the user has to clean up the data directory.
  2. General: Added the Thrifty qualifier for Website and All commandline parameters to economize on bandwidth.

version 3.6.1 (18/5/2020)

  1. Maps: Added more exception handling to Maps, more specific for Internet Timeouts. If a Timeout occurs Maps cannot complete and returns iso stopping CumulusUtils.
  2. WindRose: Older Monthly logfiles miss the current windbearing and caused a crash. This has been corrected (see note under Calculation of the WindRose).
  3. WindRose: Now the month of March is also displayed.
  4. WindRose: Improved error handling and minor HTML correction.
  5. Records: Now the month of March is also displayed (yes there was a relation with the WindRose: I copied the menu code).

version 3.6.0 (17/5/2020)

  1. DayRecords: Numbers changed from 2 decimal positions to one.
  2. ShowSolar=false now also removed the solar pane on the first dashboard.
  3. Moved NextYear, NextMonth etc... Text tags to a section called [General]. Move your translation. You can delete the old tags (leaving them won't hurt)
  4. Beta release WindRose. See Readme and release post.

version 3.5.7 (16/5/2020)

  1. Manual: Correction on the handling of Norwegian forecast wrt hourly shift.
  2. Language: Forgotten strings added (See at end of sections)
  3. Language: Moved parameters Prev and Next Year from Website section to Yadr section. Please re-translate. This may happen once in a while because it is seen as an error for modular generation.
  4. Language: Modified gauges Language.js

version 3.5.6 (13/5/2020)

  1. Language handling: correction for single quotes outside javascript.
  2. Language handling: Dashboard now shows correct (according to language) decimal, time and date separators.
  3. Known issue: sometimes a separator works well on PC but gives a different result on the RPi under Mono. That is beyond control. (may occur in other languages as well so time separator has been fixed to ':' for everybody).

version 3.5.5 (12/5/2020)

  1. Last bit of language handling: the two letter code is used as locale for CumulsuUtils and for HighCharts for specific language handling.
  2. Bugfix: you can now use a single quote in a word in the translation system.

version 3.5.4 (11/5/2020)

  1. Finalized the language handling of CumulusUtils. The two letter ISO language code now sets the language independent of the locale of the machine where Cumulus/CumulusUtils runs. See the manual.

version 3.5.4 (11/5/2020)

  1. Added the third and last phase of the translation system for CumulusUtils.

version 3.5.3 (10/5/2020)

  1. Added the second phase of the translation system for CumulusUtils (third phase, translation of the Cumulus Graphs has yet to be done).
  2. Website: Sundisc has major corrections and will now work above (below) the polar circles.
  3. Added a second Forecast possibility: the Norwegian Meteorological Organisation (https://www.yr.no/) See README on howto.
  4. README: Some corrections
  5. Website known issue: if the moon is up for more than 24 hours, it is sometimes indicated it is down for 24 hrs and the other way around. Notified the author.

version 3.5.0 (7/5/2020)

  1. Added the first phase of the translation system for CumulusUtils.

version 3.4.1 (7/5/2020)

  1. Changed the Cumulus Graphs (the opening graph) to accommodate 'Feels Like'.
  2. Introduced ini parameters for Apparent, Feels Like, Wind Chill and Heat Index for the user to select show or no show of these temperature derivatives for human perception of the weather.

version 3.4.0 (5/5/2020)

  1. New module Forecast.

version 3.3.9 (1/5/2020)

  1. Graphs: bug fix for Daily Rain graphs. The max Yearly Rain Y-scale value: when the yearly value is (much) higher than the Normal or Station value it might get off the scale. A correction has been implemented.

version 3.3.8 (30/4/2020)

  1. Graphs: bug fix for the max Yearly Rain Y-scale value: the value is now correct.
  2. Graphs: bug fix for the reference lines for the total yearly rain: they now work.
  3. Website: Color can now be set for the menu toggler (parameter: ColorToggler).

version 3.3.7 (29/4/2020)

  1. Added ColorTitleBackGroundImage ini parameter to create more personalisation. The size of the Title header won't change though.
  2. Synchronize displayed version number with the distribution.

version 3.3.6 (28/4/2020)

  1. Website Color iniparameter bugfix for Menu Background.

version 3.3.5 (27/4/2020)

  1. Website Personalisation of colours now possible.

version 3.3.0 (25/4/2020)

  1. Website: The menu changed to a responsive Bootstrap 4 default Nav/Dropdown menu.
  2. Graphs: implemented the Rain statistics per month. Again this is in fact only interesting if you have a data series of at least 3 years.
  3. If there is no website in the entry for the Map, CumulusUtils aborts. This is specifically annoying if you want to generate a website.
  4. Major update for the README concerning the graphs and the inifile parameters.

version 3.2.0 (23/4/2020)

  1. The moon had another bug.
  2. And there are 60 minutes in an hour, not 24
  3. Graphs: implemented Temperature statistics per month. This is in fact only interesting if you have a data series of at least 3 years.

version 3.1.1 (22/4/2020)

  1. The moon now shows correctly on the Southern Hemisphere.
  2. Reference lines for Average rainfall are added to the daily rainfall graph.
  3. Changed the text Barometer to Pressure (see here)
  4. Website Gen. : Changed the menu layout a bit
  5. Changes the graphs into three separate .txt files: graphsrain, graphstemp and graphsmisc to prepare for the future with the year statistics per month for temperature and rain.

version 3.1.0 (18/4/2020)

  1. Created a special version of gauges.js to accommodate the switching of the dashboard. No user action required, the library will be installed during an update overwriting the old version of gauges.js.
  2. Added latitude, longitude and altitude information to the header.
  3. Added a green LED indication station status to the left side of the menu bar.
  4. Added the following ini parameters ShowInsideMeasurements and CumulusRealTimeInterval.
  5. Maps: entries are now required to have a website entry
  6. Known Issue:
  7. at startup some non-inhibiting errors appear in the console.
  8. ShowInsideMeasurement does work for the graphs, but not for the gauges

version 3.0.6 (14/4/2020)

  1. Bug fix release to solve an issue with includes of jQuery, Highcharts and Leaflet.

version 3.0.5 (13/4/2020)

  1. Bug fix release to accommodate an issue with sync/async Ajax reads of the new cumuluscharts code.

version 3.0.4 (13/4/2020)

  1. cumuluscharts partly rewritten, now as .txt file similar to other reporting. The effect is that the json datafile can now be handled like the realtime files, it uses also CumulusRealTimeLocation for the location. The buttons are replaced by a dropdown, the graphs are the same.
  2. Prepared for the ini parameter ShowInsideMeasurements (default false) for yes/no showing the inside temperature and humidity in the graphs (rest to be done later).
  3. Added 'Browser time' to the clocks and internally reworked the clocks such that now from ANY timezone (well, some aberration maybe), you see the times of sun/moon in local time of the station. Yes, Beteljuice had warned me that time in javascript is kind of a nuisance. He was right.
  4. Known issue: time of moonset is appr. One hr off when seen from west of UTC.

version 3.0.3 (11/4/2020)

  1. Times, sun, moon are OK now in all timezones. DST might disturb somewhere on the southern hemisphere, but I think it is OK.
  2. Moon phases are now [probably] correct. Respect for Keppler and Copernicus and anybody who ever set his mind to celestial bodies, programmer or not.
  3. Responsiveness is satisfactory now for the time being.
  4. Maps show directly when clicked and to correct zoom level.
  5. About and License adjusted to wish of community (comment welcome).
  6. Known issues:
  7. Cumuluscharts needs to be rewritten because of the hardcoded location of the json data files.

version 3.0.1 (8/4/2020)

  1. Added the ini parameter CumulusRealTimeLocation to provide for a user who uses more than one website. See my notes in the README!
  2. Known issues:
  3. the times are wrong in another timezone
  4. The moonphases do not show correct.
  5. Cumuluscharts needs to be rewritten because of the hardcoded location of the json data files.

version 3.0.0 (6/4/2020)

  1. Added the website generator. See the README for how to use that.
  2. Added Wind Run to the records page

version 2.4.6 (25/3/2020)

  1. Added the command CheckOnly, to only check the dayfile.txt for errors. Any detected error can be found in the logfile. The default for the iniparameter IgnoreDataErrors has been changed to TRUE. ToDo-list: add range checks on dayfile values.
  2. Added ini parameter GeneratejQueryInclude in the section General. Current default value is true.
  3. The ini-section [Data] has been moved to [General] (see the README) (you can remove the [Data] section manually).
  4. Maps: Added try/catch error handling for an irregular occurrence of a fault while looping through the XML data structure. At a failure in the XML file, CumulusUtils aborts so other modules in the same command won't be executed. You may rerun without the Mapson command to accomplish other modules. If you run Maps and it fails, please report in a PM and send the logfile with the report.
  5. WIP: the above points concerning the ini-file are related to the construction of a new website which will become part of CumulusUtils but also as a module. CumulusUtils will always exist as a module generator for other websites, but in the end a standard website will become part of it. Some minor changes may occur in the near future in preparation, but before the website will be available. A preview of the website can be seen.

version 2.4.5 (16/3/2020)

  1. Graphs: Optimised the Monthly Temperature and Monthly Rain graphs for speed and coding efficiency.
  2. Graphs: For the same graphs, the user can choose between the Normal reference curve and the Station Average reference curve. The choice is made in the ini file with the parameters:
  3. UseNormalTempReference
  4. UseNormalRainReference
  5. Please see section of ini-parameters
  6. Graphs: for the same graphs, if the Station Reference curve is chosen, automatically the area of the standard deviation which comes with the calculation of the average is depicted in light gray in the graph.
  7. NOTE: Normal is reserved for the reference mean for the last 30 years (which normally moves up 10 years per decade) as published by the national Meteorology agencies. As Rain and Temperature are the only measurements for which there exists a Normal curve in Cumulus these will be the only curves with this feature. See further the README.

Version 2.4.1 – 2.4.2 (12/3/2020)

  1. A bug fix on 2.4.0 (inclusion of jQuery library) and addition of a Clash of Average graph (non supported, may be removed later)

version 2.4.0 (12/3/2020)

  1. Addition of the 'All' command to generate all modules which use the dayfile (so excluding Maps and SystemInfo).
  2. Cleaned up the log generation from redundant entries.
  3. Modified the selection interfaces where necessary, addition of prev/next buttons (and moved it all to jQuery in the process).
  4. Added 'total yearly rain to date' as an entity and published it on the Records, Dayrecords pages and Daily Rain graph as cumulative amount.
  5. Reviewed tables (records, dayrecords, top10 and yadr), such that iframe should not be necessary. Settings are now width=100% (of the enclosing div) and max-width=1000px (to prevent stretching the whole width of large monitors). Please check.
  6. Removed the Climate module and integrated it with the Graphs module. Sorry, that was short lived. Please be prepared that this Graphs reporting part is Work In Progress and changes because of requests, thoughts and philosophies may have some effect in future.
  7. All graphs have become optional with the possibility to switch on/off through ini-file parameters in the Graphs section (I assume this self evident). NOTE: the graphs are generated, it is only the HTML menu choice which is off.

version 2.3.0 (8/3/2020)

  1. YADR: Fixed a bug where temperature of exactly -1 degree (C/F) was seen as invalid and no low temperature in the month summary was filled in.
  2. DayRecords/Records: Added and improved parametrization of the header texts. Please find in strings section in ini file to translate.
  3. Records: Applied colouring of header and record text analogue to top10 module using the top10 format from the ini file (30 day record retention time).
  4. Started a climate graphing module.
  5. Implemented temperature HeatMap for Climate Graphs.
  6. Implemented Climate statistics on temperature and Rain (to be possibly modified and or expanded to other measurements). Comment is welcome.

version 2.2.6 (5/3/2020)

  1. Corrected the relation between the header and the values for the wind measurements
  2. Fixed bug in drop down selection menu for records, dayrecords and noaa modules generation, where a crash occurred if there were no months to disable (pretty elementary error, sorry).

version 2.2.5 (4/3/2020)

  1. Addition of NOAA reports display (nothing new there, just part of CumulusUtils required for the future)
  2. The year/month selection where months must have data. So e.g. future months in the current year are greyed out and cannot be selected. Similar in the first year, or all years when just starting (for both NOAA and records module).
  3. Addition of Day Records module.

version 2.2.2 (27/2/2020)

  1. Optimisation of records module

version 2.2.1 (27/2/2020)

  1. Optimisation of records module
  2. Fixed a bug for display of month of March (all years)

version 2.2.0 (25/2/2020)

  1. Another minor legend correction in YADR
  2. Addition of the CumulusUtils version of a records page including some corresponding ini parameters (Strings section).

version 2.1.7 (28/1/2020)

  1. Correction on 2.1.6 for different units in YADR

version 2.1.6 (28/1/2020)

  1. Corrected the README where necessary
  2. Dayfile reading: Finalized the error handling of skipping the line containing the error. All info for each error will now be in the logfile.
  3. YADR: changed wind value format to one (1) decimal accuracy
  4. YADR: changed humidity values to zero (0) decimal accuracy
  5. YADR NOTE: Title of barometric values should contain ‘Average’. This has been added to the default but it won’t change automatically if it is already in your ini-file.
  6. YADR: the legends now also are correct for all units available (the only site where this can be seen/checked is “‘t Zandt”).
  7. Addition of Phil’s EasterEgg. Hint: check the cumulusutils.ini after run of 2.1.6 and read this thread backwards. Can’t be too difficult if you’re a regular follower.

version 2.1.0 (22/1/2020)

  1. Maps: Technical correction concerning refresh of station
  2. Reading Dayfile: Complete overhaul and creation of internal datalist
  3. Added: possibility to continue reading the data file in case of data errors (see README on cumulusutils.ini, section: Data)
  4. YADR: Correction for legend of Humidity and Pression
  5. Top10: Overhaul of selection/sorting mechanism (incomplete but working, three more items to go but these may be difficult to do in LINQ with just a few queries so... maybe not)
  6. Top10: Corrected an error in the output table and at the same time slightly modified the <Style>

version 2.0.3 (5/1/2020)

  1. Some code optimisation
  2. Graphs: Daily rain graph now has right Y-axis cross x-axis at 0
  3. pwsFWI: Number of records shown is now conform Analysis figure from the inifile or 30 otherwise. The number is including predictive days.
  4. pwsFWI: Unit for RH in pwsFWI webtable: % is removed in header
  5. YADR: Unit for RH changed to % (was deg. Celsius/Fahrenheit).
  6. All modules: Correction of effect of prediction in pwsFWI (had not been noticed by anybody so far ;)

version 2.0.2 (5/12/2019)

  1. Yadr: Corrected the colour key for rain table
  2. Corrected code in the inifile handling so Mono v4 can be used (see here, will not be permanent I hope).

version 2.0.1 (2/12/2019)

  1. Yadr: some bug fixes, removed the reference to Yadr.css
  2. Yadr: changed to white for the numbers in some cases to account for better readability of the numbers against darker colours.
  3. Yadr: Added Humidity.
  4. Yadr: Titles and fixed translatable texts are parameterized in the inifile in the section [Strings]. Parameter names start with Yadr.
  5. Graphs: changed the ‘Daily Rain’-graph to a stock-type graph to account for easier handling and zooming.

version 2.0.0 (29/11/2019)

  1. Yadr – Yet Another Dayfile Reader added as standard functionality. Read the README concerning the use (amount of datafiles and the use of the internal FTP)

version 1.9.7 (21/11/2019)

  1. Addition of Internal FTP upload. Read the README for explanation
  2. Fix for kocher (intermediate version 1.9.6).

version 1.9.5 (18/11/2019)

  1. Maps: Website will now be opened in a new tab (or window, depending on the configuration of your Browser)
  2. Code optimisation and error handling changes.

version 1.9.4 (17/11/2019)

  1. Maps: Added a last alive date to the marker popup, preparation for eventually a validity cleanup.
  2. Optimized the XML/Linq code.
  3. Added some error handling (e.g. for duplicate names). May not be complete yet but it requires the live run to evaluate.
  4. Removed MapBox libraries/reference and prepared for OpenStreetMap only. Waiting for response from OSM in relation to using the tile server.

version 1.9.3 (16/11/2019)

  1. Maps: if comma decimal separator in lat/lon then set it to point to have lat/lon handled correctly by the map java.
  2. pwsFWI: fix for colour of the pointer of 1.9.0 was refixed.
  3. Maps: Website entry for the popup is created in cumulusutils.ini

version 1.9.2 (15/11/2019)

  1. Maps: bug fix: now all stations show on map, not just the first one.
  2. pwsFWI: credit for the prediction must be in the correct

version 1.9.0 (15/11/2019)

  1. pwsFWI: Bug fix for the flashing of the pointer which takes the colour of the fifth prediction day but must have colour of the last calculated day (Current value).
  2. Introduction of module Maps.

version 1.8.4 (5/11/2019)

  1. pwsFWI: The prediction module can now be used with all units available in Cumulus. Although the interface always (unchangable) uses km/h, mbar, deg C and mm, it does no longer interfere with the normal readings of the user settings for the units.

version 1.8.3 (2/11/2019)

  1. Graphs: TempvsNOAA and RainvsNOAA now both work correctly at the first of month (they used to display Nul (0) as a first day value).
  2. The table of pwsFWI displays the numbers in CurrentCulture format (e.g. a comma as decimal separator in NL, a point probably in a lot of other places). This makes it easier to cut/paste to Excel or Google Sheets. Same holds for the Analysis csv file.

version 1.8.2 (2/11/2019)

  1. Graphs/pwsFWI: the degree symbol (again) is now OK everywhere.
  2. This is not a functional release but a maintenance release concerning a problem which occurred in Poland and France where the prediction in pwsFWI was aborted.

version 1.8.1 (31/10/2019)

  1. Graphs/pwsFWI: the degree symbol before Celsius or Fahrenheit is now encoded as Unicode 00B0 for javascript/Highcharts and as ° for HTML and should display always and everywhere it is required. Yes, it now truly is... (I hope)
  2. The observation about minimum humidity was correct and has been fixed. Now the lowest prediction of all three hour blocks is entered in the calculations and the prediction table (thanks to meteosangonera for looking deep into the system!)

version 1.8.0 (30/10/2019)

  1. Graphs/pwsFWI: the degree symbol before Celsius or Fahrenheit is now encoded as Unicode 00B0 and should display always and everywhere it is required.
  2. In Graphs, the Go button has been moved to the right side of the graph selector.
  3. In SysInfo, The Linux rPi OS now has a description e.g. Raspbian GNU/Linux 10 (buster) besides only the numerical version.
  4. pwsFWI: A predictive system - 5 days - has been created for pwsFWI. This is a relatively complex and major change. Please read the ReadMe on how to activate and use it.

version 1.7.2 (27/10/2019)

  1. In the Monthly Temp and Monthly Rain graphs, the MaxNrOfSeriesVisibileInGraph, now is valid for the most recent years iso the first years.

version 1.7.1 (25/10/2019)

  1. Initially in the Monthly Rain and Monthly Temp graphs only MaxNrOfSeriesVisibileInGraph series are shown. This ini-parameter defaults to 2. If you set it to a number greater than the number of series you have, all series are displayed;
  2. Created a new colour set to avoid conflict with the black normal series and create more contrast. Currently 13 colours are defined, more than 13 series start reusing the colours.
  3. The colour series are added to the Graphs section in the inifile so every user can change the defaults. If a graph does not use the default colours, it's colours will be hard coded and no users interference can be made.
  4. NOTE: comments are allowed in the inifile: first character on the line must be ";". Empty lines remain as does a sorting done by the user.

version 1.7.0 (22/10/2019)

  1. The Normal series in the Graphs now always have the colour black;
  2. All zero-valued series points were not printed. That has been changed to: zero-valued series points outside the series (incomplete years) are not plotted, zero-valued series data are plotted;
  3. The inifile handling has been greatly revised to facilitate the strings (see next bullet point). Most notably: an empty or nonexistent ini will be reinitialised. User values remain valid until deleted which resets default. A deleted or non existent key will be created when needed. Limited space for strings will need to be determined by trial and error. Sorting and replacing sections and keys remain in tact, empty lines disappear;
  4. Strings are added to the inifile to facilitate CumulusUtils to show a different language. CumulusUtils will not have the possibility to switch languages at runtime. The tags are - I think - self explanatory. If anybody has a problem, please let me know;
  5. Units are added to the graphs and will show what is used by Cumulus. Note: in pwsFWI all imperial values are converted implicitly to metric because the meteorological formula's are metric. Therefore the table in pwsFWI only metric values are shown and not the imperial values.

version 1.6.7 (19/10/2019)

  1. My bad: I noticed that every installation used a 30 day period for the daily rain graph and could not change it. That has been corrected.
  2. The 'Normal' values in the NOAA settings apparently are written under the regime of the locale which means the decimal separator can be either comma or point. Cumulus 1 and 3 seem different in this respect (I could not be 100% sure) so I created a workaround to always read it correctly, whichever format. The decimal separator is assumed to be only point or comma.

version 1.6.5 (18/10/2019)

  1. Formal release of the Graphs module.
  2. Added ini parameter for MovingAveragePeriod (default 180)
  3. Changed title of graph Daily Rainfall and added period to x-axis title;
  4. Changed some minor things in layout of graphs;
  5. Added new graph: rain per month (With Normal Value line);
  6. Top10: Removed the output top10TableStyle.txt (please remove the corresponding include from your website). Only one files exists for top10: top10Table.txt. There should be no difference.

version 1.6.2 (16/10/2019)

  1. Bug fix for the position of the credits under the pwsFWI and top10 tables;
  2. Some minor spaces/CSS fixes;
  3. Major fix for Graphs, which inhibited it to run correctly when top10 would be demanded in the same run;
  4. Major fix for Graphs which did not show the graph when an apostrophe was in the LocDesc string in Cumulus.ini. The apostrophe is now permitted.
  5. Added the Monthly Temperature graph. See above.

version 1.6.0 (14/10/2019)

  1. Because some of you put all their data online with the pwsFWI module, the interface has been adapted by beteljuice, to account for a better handling of some 4000 lines. It now uses a small window of roughly 22 lines and a scrollbar. The headers remain locked.
  2. As a kind of giveaway Easter Egg, you will also find a first version of the graphs module (commandline parameter 'graphs'). Two graphs have been implemented so far. There is a drop down choice which graph you want to see. Feedback with comments and wishes is appreciated. So far this is not a release and no options for the graphs have been implemented yet.

version 1.5.1 (12/10/2019)

  1. Some finetuning of the web interface pwsFWI (also known as bug fixing): 1)border spacing of table now correct; 2)Legend now also in Standard; 3)pwsFWIcurrent now has a beteljuice approved styling;
  2. Check for a minimum nr of lines (currently 35) in dayfile.txt for useful results.

version 1.5.0 (9/10/2019)

  1. A sixth warning level has been added to pwsFWI, named: Catastrophic, colour purple. The parameter in the inifile is WarningLevel, possible values : 5 or 6. Read the ABC article below.
  2. Some bug fixes around the red warning level where it was changed to green or where the indicator was supposed to be in the green zone but remaind red.
  3. The process of the Smoothing and Quenching has been slightly changed to better process single rain shower events. (See blog: "Behaviour of pwsFWI with first rain").
  4. For pwsFWI and extra output has been created: pwsFWIcurrent.txt, containing an HTML -tag, for the required colour. To use wherever the use wants the dayvalue, e.g. on the frontpage dashboard (see my site for an example).
  5. All output now will be written to a subdirectory utils/ one level below the Cumulus main directory. Only cumulusutils.exe (and possible libraries) and the cumulusutils.ini remain in the Cumulus directory.
  6. Fixed an algorithmic bug in pwsFWI, not yet exposed, which caused a problem when analysis would be exactly the amount of days in dayfile.

version 1.0.1 (3/10/2019)

  1. In top10, unit 'percentage' has changed to '%'

version 1.0.0 (30/9/2019)

  1. Good enough for version 1.0.0
  2. The Analysis csv file is now governed by the locale which means date, separators and decimal point are written conform the locale on the machine where cumulusutils runs. This should make it easier to open it with excel.
  3. Changed copyright notice / text under the tables.
  4. Fixed scaling when pwsFWI value surpassed value outside scale

version 0.9.1 (26/9/2019)

  1. Changes to the meteorological equations used for Vapour Deficit (see my blog of 26 sep 2019).
  2. Closed a call on SysInfo: Windows 8 really needs to have its updates.
  3. Several minor bugfixed/tunings in the Beteljuice-format.
  4. Code cleanup and minor fixes.

version 0.9.0 (24/9/2019)

  1. Bug fix: sysinfo under Windows (any version) now breaks off if resultstrings are unexpected. Message displayed in logfile, please send. However, errorhandling before that happens has been improved (again).
  2. Two pwsFWI result formats are now available: Standard and Beteljuice. The latter of course the better. (Thanks to Beteljuice, takes a lot of time iteration and testing though). Note the corresponding ini-parameters!

version 0.8.8 (22/9/2019)

  1. Bug fix: monthly rainfall did not show in top10 if the station was running ten or more months.
  2. Changed header of pwsFWI table: "Drought" was changed to "Consecutive days without rain"
  3. Ran spellchecker on this file

version 0.8.7 (21/9/2019)

  1. Functional change/Bug fix: The pwsFWI CSV-file now has a slightly different format. All figures are now floating point with max. two decimal accuracy (except for the drought period which are in days). This is generated without CultureInfo so, I assume the decimal period (or comma) is according to your machine setting (which is why I changed the comma separation to the semicolon). Let me know if this functions the wrong way.

version 0.8.6 (21/9/2019)

  1. Bug fix: During the updating of cumulusutils.ini erroneously Analysis was always reset to its default value.

version 0.8.5 (20/9/2019)

  1. Bug fix: high monthly rainfall in top10 table fixed if station runs less than 10 month. Top10 table now contains no entries for months without data.
  2. Dry period added to the pwsFWI table.
  3. Changed some table width.
  4. Exception handling now should be generic. IF(!) an exception occurs, the exceptions should always be handled such that the application recovers or ends with a graceful exit with enough info in the log file. The exception message is always printed in the log including a possible stackdump.
  5. The stations should have at least 30 days of days of data for top10. Otherwise this application will not run correctly. That has been taken care of.
  6. Analysis possibility for pwsFWI. See above in functionality.
  7. SysInfo page has now elaborate try/catch errorhandling on all system accesses, looking for information. If no information is found or in case of error, 'unknown' is written on the webpage. The variety within Linux/Unix is troublesome. Since there is no generic command to find the temperature of the processor, only for Raspberry it is known. Therefore I left that out.

version 0.7.5 (19/9/2019)

  1. All dayfile's can be used now, metric or imperial units will be handled and for the calculations of pwsFWI the conversions are automatically made. Let me know if you spot an anomaly.
  2. Headers of the top10 table now include the unit of measurement
  3. Headers of the top10 table now can be translated via the cumulusutils.ini
  4. some corrections and code cleanup

version 0.7.0 (18/9/2019)

  1. Made a ReadMe
  2. Finished the implementation of the ini-handling
  3. some corrections and code cleanup

version 0.6.5 (17/9/2019)

  1. Completed the System Info page which is now also available for Windows 10 (maybe also lower versions, if not, let me know).
  2. Reading of the Cumulus.ini is now complete. This means that a lot of information can now be used and the preparations for a cumulusutils.ini are finished.
  3. Minor changes everywhere. Cleaning up.

version 0.6.0 (16/9/2019)

  1. Added a System Info page for Unix/Linux. Run with command line parameter -ftp.

version 0.5.3 (16/9/2019)

  1. Solved a technical problem in pwsFWI which had a big functional effect.
  2. Added a factor to pwsFWI to account for the duration of a drought period. In future the weight of this factor may change slightly.

version 0.5.1

  1. Currently version 0.5.1 and the pwsFWI has now info with links and info. If you disagree and would like to see changes, please let me know.
  2. The executable now creates a cumulusutils.log. If any problems occur, please send it when you contact me, this may help out.
  3. I solved a rPi problem in converting the numbers from ascii to floats and doubles etc. C# is pretty tricky on this issue and there's a steep learning curve on my side. Hope I got it all right by now, but it is not impossible you see something strange on different machines.