[
    {
        "test_name": "cb_two_action",
        "data_func": {
            "name": "generate_cb_data",
            "params": {
                "num_examples": 100,
                "num_features": 1,
                "seed": 1,
                "action_range": [
                    0,
                    2
                ],
                "reward_function": {
                    "name": "piecewise_constant",
                    "params": {
                        "reward": [
                            1,
                            0
                        ]
                    }
                },
                "logging_policy": {
                    "name": "even_probability",
                    "params": {}
                }
            }
        },
        "assert_functions": [
            {
                "name": "assert_loss",
                "params": {
                    "expected_loss": -1,
                    "decimal": 1
                }
            },
            {
                "name": "assert_prediction",
                "params": {
                    "expected_value": [
                        1,
                        0
                    ],
                    "threshold": 0.8
                }
            }
        ],
        "grids": {
            "cb": {
                "#base": [
                    "--cats 2 --min_value 0 --max_value 2 --bandwidth 1"
                ]
            },
            "epsilon": {
                "--epsilon": [
                    0.1,
                    0.2,
                    0.3
                ]
            }
        },
        "grids_expression": "cb * (epsilon)",
        "output": [
            "--readable_model",
            "-p"
        ]
    },
    {
        "test_name": "cb_two_action_diff_context",
        "data_func": {
            "name": "generate_cb_data",
            "params": {
                "num_examples": 100,
                "num_features": 2,
                "seed": 1,
                "action_range": [
                    0,
                    2
                ],
                "reward_function": {
                    "name": "fixed_reward_two_action",
                    "params": {}
                },
                "logging_policy": {
                    "name": "even_probability",
                    "params": {}
                },
                "context_name": [
                    "1",
                    "2"
                ]
            }
        },
        "assert_functions": [
            {
                "name": "assert_loss",
                "params": {
                    "expected_loss": -0.8,
                    "decimal": 1
                }
            },
            {
                "name": "assert_prediction",
                "params": {
                    "expected_value": [
                        0.975,
                        0.025
                    ],
                    "threshold": 0.1,
                    "atol": 0.1,
                    "rtol": 0.1
                }
            }
        ],
        "grids": {
            "cb": {
                "#base": [
                    "--cats 2 --min_value 0 --max_value 2 --bandwidth 1"
                ]
            },
            "epsilon": {
                "--epsilon": [
                    0.1,
                    0.2,
                    0.3
                ]
            }
        },
        "grids_expression": "cb * (epsilon)",
        "output": [
            "--readable_model",
            "-p"
        ]
    },
    {
        "test_name": "cb_one_action",
        "data_func": {
            "name": "generate_cb_data",
            "params": {
                "num_examples": 10,
                "num_features": 1,
                "seed": 1,
                "action_range": [
                    0,
                    1
                ],
                "reward_function": {
                    "name": "fixed_reward",
                    "params": {}
                },
                "logging_policy": {
                    "name": "even_probability"
                }
            }
        },
        "assert_functions": [
            {
                "name": "assert_loss",
                "params": {
                    "expected_loss": -1
                }
            },
            {
                "name": "assert_prediction",
                "params": {
                    "expected_value": [
                        0,
                        1
                    ],
                    "threshold": 0.1
                }
            }
        ],
        "grids": {
            "g0": {
                "#base": [
                    "--cats 2 --min_value 0 --max_value 1 --bandwidth 1"
                ]
            },
            "g1": {
                "--cb_type": [
                    "ips",
                    "mtr",
                    "dr",
                    "dm"
                ]
            }
        },
        "grids_expression": "g0 * g1",
        "output": [
            "--readable_model",
            "-p"
        ]
    }
]