-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathtrain_model.py
113 lines (90 loc) · 3.71 KB
/
train_model.py
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
# Copyright 2020-2021, The Johns Hopkins University Applied Physics Laboratory LLC
# All rights reserved.
# Distributed under the terms of the Apache 2.0 License.
from simple_model_env import SimpleCropModelEnv
from simple import BentonWACSVWeatherSchedule, WeatherForecastSTDs, PotatoRussetUSACropParametersSpec
import datetime
import gym
import os
import ray
from ray.tune.registry import register_env
from ray.rllib.models import ModelCatalog
import ray.rllib.agents.sac as sac
import ray.rllib.agents.ppo as ppo
from ray.tune.schedulers import ASHAScheduler
import numpy as np
class SimpleCropModelEnvWrapper(gym.ObservationWrapper):
def __init__(self, env):
super().__init__(env)
self.observation_space = gym.spaces.Box(-np.inf, np.inf, shape=(20,), dtype=np.float64)
def observation(self, observation):
"""
Realistic observations include:
- Noisy reading of cumulative biomass (such as might be estimated from an image of the plant?)
- Cumulative mean temp (seems relatively measurable)
- Days since sowing date
- Weather from last day
- Noisy reading of root zone available water
which correspond to
- noisy biomass: obs[1]
- cumulative mean temp: obs[2]
- Day: obs[3]
- Today's weather: obs[4: 11]
- Tomorrows forecast (noisy ground truth): obs[19: 27]
- Noisy RZW: obs[29]
"""
return observation[list(range(1, 12)) + list(range(19, 27)) + [29]]
def register():
register_env("SimpleModelEnv", lambda cfg: SimpleCropModelEnvWrapper(SimpleCropModelEnv(**cfg)))
# ModelCatalog.register_custom_model("atari", AtariNetwork)
def train_on_simple():
ray.init(ignore_reinit_error=True,
num_cpus=5)
# config = sac.DEFAULT_CONFIG.copy()
config = ppo.DEFAULT_CONFIG.copy()
register()
env_name = "SimpleModelEnv"
config['env'] = env_name
# config['model'] = dict(custom_model="atari", custom_model_config={'policy_dim': 6})
config['framework'] = 'torch'
config["num_workers"] = 4 # from ETN defaults
# config['lr'] = 0.00025 # from ETN defaults
# config['lambda'] = 0.95 # from ETN defaults
# config["timesteps_per_iteration"] = 240
# config['vf_loss_coeff'] = ray.tune.grid_search([0.5, 0.8, 1.0]) # from ETN defaults
# config['clip_param'] = 0.2 # from ETN defaults
# PPO config
csv_path = 'data/daily_weather_ag_data_washstateu.csv'
env_cfg = dict(
sowing_date=datetime.datetime(day=1, month=4, year=2000),
num_growing_days=120,
weather_schedule=BentonWACSVWeatherSchedule(csv_path),
weather_forecast_stds=WeatherForecastSTDs(),
latitude=43.9271,
elevation=1464,
crop_parameters=PotatoRussetUSACropParametersSpec(),
)
config["env_config"] = env_cfg
asha_scheduler = ASHAScheduler(
time_attr='training_iteration',
metric='episode_reward_mean',
mode='max',
max_t=8000,
grace_period=750, # min time-steps to run before considering termination
reduction_factor=4,
brackets=1
)
# ray.tune.run("SAC",
# local_dir='./ray_results/',
# stop={"timesteps_total": 1e6, "episode_reward_mean": 95},
# checkpoint_freq=10000,
# checkpoint_at_end=True,
# config=config)
ray.tune.run("PPO",
local_dir='./ray_results/',
stop={"agent_timesteps_total": 1000000, "episode_reward_mean": 60000},
checkpoint_freq=50,
checkpoint_at_end=True,
config=config)
if __name__ == "__main__":
train_on_simple()