2021-05-24 07:06:10 +02:00
|
|
|
import math
|
2021-05-09 12:53:18 +02:00
|
|
|
from .synthetic_utils import TimeStamp
|
2021-04-28 17:56:25 +02:00
|
|
|
from .synthetic_env import SyntheticDEnv
|
2021-05-09 13:11:56 +02:00
|
|
|
from .math_core import LinearFunc
|
|
|
|
from .math_core import DynamicLinearFunc
|
|
|
|
from .math_core import DynamicQuadraticFunc
|
2021-05-26 03:17:38 +02:00
|
|
|
from .math_core import ConstantFunc, ComposedSinFunc as SinFunc
|
2021-05-24 07:06:10 +02:00
|
|
|
from .math_core import GaussianDGenerator
|
2021-04-28 17:56:25 +02:00
|
|
|
|
|
|
|
|
2021-05-09 12:53:18 +02:00
|
|
|
__all__ = ["TimeStamp", "SyntheticDEnv", "get_synthetic_env"]
|
|
|
|
|
|
|
|
|
2021-05-26 03:17:38 +02:00
|
|
|
def get_synthetic_env(total_timestamp=1600, num_per_task=1000, mode=None, version="v1"):
|
|
|
|
max_time = math.pi * 10
|
|
|
|
if version == "v1":
|
2021-05-24 14:55:14 +02:00
|
|
|
mean_generator = ConstantFunc(0)
|
|
|
|
std_generator = ConstantFunc(1)
|
|
|
|
data_generator = GaussianDGenerator(
|
|
|
|
[mean_generator], [[std_generator]], (-2, 2)
|
|
|
|
)
|
|
|
|
time_generator = TimeStamp(
|
2021-05-26 03:17:38 +02:00
|
|
|
min_timestamp=0, max_timestamp=max_time, num=total_timestamp, mode=mode
|
2021-05-24 14:55:14 +02:00
|
|
|
)
|
|
|
|
oracle_map = DynamicLinearFunc(
|
|
|
|
params={
|
2021-05-26 03:17:38 +02:00
|
|
|
0: SinFunc(params={0: 2.0, 1: 1.0, 2: 2.2}), # 2 sin(t) + 2.2
|
|
|
|
1: SinFunc(params={0: 1.5, 1: 0.6, 2: 1.8}), # 1.5 sin(0.6t) + 1.8
|
2021-05-24 14:55:14 +02:00
|
|
|
}
|
|
|
|
)
|
|
|
|
dynamic_env = SyntheticDEnv(
|
|
|
|
data_generator, oracle_map, time_generator, num_per_task
|
|
|
|
)
|
2021-05-26 03:17:38 +02:00
|
|
|
elif version == "v2":
|
2021-05-09 12:53:18 +02:00
|
|
|
mean_generator = ConstantFunc(0)
|
|
|
|
std_generator = ConstantFunc(1)
|
2021-05-24 07:06:10 +02:00
|
|
|
data_generator = GaussianDGenerator(
|
|
|
|
[mean_generator], [[std_generator]], (-2, 2)
|
2021-05-09 12:53:18 +02:00
|
|
|
)
|
2021-05-24 07:06:10 +02:00
|
|
|
time_generator = TimeStamp(
|
2021-05-26 03:17:38 +02:00
|
|
|
min_timestamp=0, max_timestamp=max_time, num=total_timestamp, mode=mode
|
2021-05-09 12:53:18 +02:00
|
|
|
)
|
2021-05-26 03:17:38 +02:00
|
|
|
oracle_map = DynamicQuadraticFunc(
|
2021-05-24 07:06:10 +02:00
|
|
|
params={
|
2021-05-26 03:17:38 +02:00
|
|
|
0: LinearFunc(params={0: 0.1, 1: 0}), # 0.1 * t
|
|
|
|
1: SinFunc(params={0: 1, 1: 1, 2: 0}), # sin(t)
|
2021-05-24 07:06:10 +02:00
|
|
|
}
|
|
|
|
)
|
|
|
|
dynamic_env = SyntheticDEnv(
|
|
|
|
data_generator, oracle_map, time_generator, num_per_task
|
2021-05-09 13:05:07 +02:00
|
|
|
)
|
2021-05-09 12:53:18 +02:00
|
|
|
else:
|
|
|
|
raise ValueError("Unknown version: {:}".format(version))
|
2021-04-28 17:56:25 +02:00
|
|
|
return dynamic_env
|