1 from predictops.source.ephemeris import Ephemeris
2 from predictops.source.meteofrance import MeteoFrance
3 from predictops.learn.preprocessing import Preprocessing
4 from predictops.target.toarea import ToArea
6 from datetime import datetime, timedelta
7 from logging import getLogger
8 from logging.config import fileConfig
9 from pathlib import Path
10 from shutil import rmtree
12 import geopandas as gpd
14 fileConfig((Path.cwd() / 'config') / 'logging.cfg')
19 def __init__(self, start = None, end = None, time_step = None):
25 # Cleaning the data directory
26 logger.info("Cleaning and restoring data directory")
27 directory = Path.cwd() / 'data'
28 if directory.is_dir():
30 p = Path(Path.cwd() / 'data')
34 def add_feature(self, name, **kw):
36 if name == 'meteofrance':
37 meteofeature = MeteoFrance(**kw)
39 dated_features = meteofeature.dated_features
40 for date in dated_features:
41 self._X.setdefault(date,{}).update(dated_features[date])
42 elif name == 'ephemeris':
43 ephemerides = Ephemeris(**kw)
44 dated_features = ephemerides.dated_features
45 for date in dated_features:
46 self._X.setdefault(date,{}).update(dated_features[date])
58 start = datetime.strptime('01/01/2010 00:00:00', '%m/%d/%Y %H:%M:%S')
59 end = datetime.strptime('12/31/2010 23:00:00', '%m/%d/%Y %H:%M:%S')
62 engine.add_feature(name = 'meteofrance',
63 start = start, end = end,
64 latitude = 47.25, longitude = 6.0333, nb_stations = 3,
65 features = ['temperature', 'pressure'])
67 engine.add_feature(name = 'ephemeris',
68 start = start, end = end,
69 features = ['hour', 'dayInWeek', 'dayInMonth', 'dayInYear',
70 'weekInYear', 'month', 'year'])
72 process = Preprocessing(dict_features = engine.X,
73 start = start, end = end, timestep = timedelta(hours=1))
76 print(process.dataframe.head(n=20))
77 #print(engine.X[datetime.strptime('06/30/2010 21:00:00', '%m/%d/%Y %H:%M:%S')])
81 depts = gpd.read_file( Path.cwd() / 'data' / 'targets' / 'departments' / "departements-20180101.shp")
82 Doubs = depts.loc[depts['nom'] == 'Doubs'].iloc[0]
84 ToArea(area=Doubs.geometry,
85 start = start, end = end,
86 csv_file = Path.cwd() / 'data' / 'targets' / 'sdis25' / 'interventions.csv')