Applying classical and Deep-Learning algorithms to time-series data, collected through Prometheus (Thanos).
In this project, we wish to write an API that performs the following tasks:
- Poll data from Prometheuse constantly. On this data we will use our classical and Deep-Learning algorithms.
- Organize the data in an orderly fasion on the local computer running the queries (see file-paths before running).
- Offer the user to pick the following parameters when performing forecasting and error calculation (goodness of a forecasting method on the data-set):
- Metric(cpu or memory in this case).
- Application(from the applications monitored - see list in data_get/utils.py).
- Forecasting method(See implemented methods in forecasting/Methods.py).
- Test segment length(proportional to whole data-length).
- Granularityof the data.
- Compression methodused to aggregate data-samples to the wanted granularity.
- Error metric.
 
Other than these options, the user can also choose if he wants to:
- Traverse the whole data-set, aggregating the error of a specific metric and application using a specific forecasting method.
- Traverse the data-set, until finding one of the results received for specific metric and application, and plotting the forecast (and train period) of that data-sample (this option will also print the error).
All these options are chosen by the user via the menu-interface that is printed to the user (see forecasting/main_fore.py).
Time-series (ts) forecasting has been a major field interested and invested in by the industry for the last 10-20 years. In years prior to 2019, mainly classical forecasting algorithms were used (e.g., ARIMA models, exponential smoothing etc.). In 2019, a brakethrough was achieved for forecasting using Deep-Learning methods (See DeepAR). From then an on, forecasting via Deep-Learning methods gained more and more attention, resulting in some very good models used today. In this project we wish to implement some of the classical methods, along with some Deep-Learning methods, and apply them to a data-set of time-series we will aggregate throughout the project timeline.
From the root directory, run
python forecasting/main_fore.py
in order to run the menu-code from which you can choose the forecasting parameters. Executing this module will also run the forecasting method chosen on the data chosen, and plot the result or aggregate the loss respectively to the choice of 'plot one?'.
There are many supplamentary methods you can run in order to manually control the data inserted, the forecasting method parameters etc.
There are many options to execute more specific tasks, see forecasting package.