int
main(int argc, char **argv)
{
    Air_Conditioner_Controller acc;
    struct sml_variable *temp, *presence, *power;
    struct sml_object *sml;

    _initialize_acc(&acc);

    if (argc != 2) {
        fprintf(stderr, "Usage: %s <engine_type (0 fuzzy, 1 ann)>\n", argv[0]);
        fprintf(stderr, "Fuzzy Test: %s 0\n", argv[0]);
        fprintf(stderr, "Ann Test: %s 1\n", argv[0]);
        return -1;
    }

    sml = _sml_new(atoi(argv[1]));
    if (!sml) {
        sml_critical("Failed to create sml");
        return -1;
    }

    sml_main_loop_init();

    //Set stabilization hits and initial required obs to a low value because
    //this is a simulation and we don't want to wait for a long time before
    //getting interesting results
    sml_set_stabilization_hits(sml, STABILIZATION_HITS);
    sml_ann_set_initial_required_observations(sml, INITIAL_REQUIRED_OBS);

    //Create temperature input
    temp = sml_new_input(sml, "Temperature");
    sml_variable_set_range(sml, temp, 0, 48);
    sml_fuzzy_variable_set_default_term_width(sml, temp, 16);

    //Create presence input
    presence = sml_new_input(sml, "Presence");
    sml_variable_set_range(sml, presence, 0, 1);
    sml_fuzzy_variable_set_default_term_width(sml, presence, 0.5);

    //Create power output
    power = sml_new_output(sml, "Power");
    sml_variable_set_range(sml, power, 0, 3);
    sml_fuzzy_variable_set_default_term_width(sml, power, 1);
    sml_fuzzy_variable_set_is_id(sml, power, true);

    //set SML callbacks
    sml_set_read_state_callback(sml, _read_state_cb, &acc);
    sml_main_loop_schedule_sml_process(sml, READ_TIMEOUT);
    sml_set_output_state_changed_callback(sml, _output_state_changed_cb, &acc);

    sml_main_loop_run();

    sml_free(sml);
    sml_main_loop_shutdown();
    return 0;
}
static void
add_time_day(Context *ctx)
{
    int i;
    char term_name[8];

    if (ctx->enable_time_input && ctx->time_blocks) {
        ctx->time = sml_new_input(ctx->sml, TIME_STR);
        sml_variable_set_range(ctx->sml, ctx->time, 0, ctx->time_blocks);
    }

    if (ctx->enable_weekday_input) {
        /* Mon == 0; Sun == 6 */
        ctx->weekday = sml_new_input(ctx->sml, WEEKDAY_STR);
        sml_variable_set_range(ctx->sml, ctx->weekday, 0, 7);
    }

    if (ctx->engine_type != FUZZY_ENGINE &&
        ctx->engine_type != FUZZY_ENGINE_NO_SIMPLIFICATION)
        return;

    //create fuzzy terms
    if (ctx->time) {
        snprintf(term_name, sizeof(term_name), "%d",  0);
        sml_fuzzy_variable_add_term_ramp(ctx->sml, ctx->time, term_name, 1, 0);
        for (i = 1; i < ctx->time_blocks - 1; i++) {
            snprintf(term_name, sizeof(term_name), "%d",  i);
            sml_fuzzy_variable_add_term_triangle(ctx->sml, ctx->time,
                term_name, i - 1, i, i + 1);
        }
        snprintf(term_name, sizeof(term_name), "%d",  i);
        sml_fuzzy_variable_add_term_ramp(ctx->sml, ctx->time, term_name, i - 1,
            i);
    }

    if (ctx->weekday) {
        sml_fuzzy_variable_add_term_triangle(ctx->sml, ctx->weekday,
            "Monday", 0, 0.5, 1);
        sml_fuzzy_variable_add_term_triangle(ctx->sml, ctx->weekday,
            "Tuesday", 1, 1.5, 2);
        sml_fuzzy_variable_add_term_triangle(ctx->sml, ctx->weekday,
            "Wednesday", 2, 2.5, 3);
        sml_fuzzy_variable_add_term_triangle(ctx->sml, ctx->weekday,
            "Thursday", 3, 3.5, 4);
        sml_fuzzy_variable_add_term_triangle(ctx->sml, ctx->weekday,
            "Friday", 4, 4.5, 5);
        sml_fuzzy_variable_add_term_triangle(ctx->sml, ctx->weekday,
            "Saturday", 5, 5.5, 6);
        sml_fuzzy_variable_add_term_triangle(ctx->sml, ctx->weekday,
            "Sunday", 6, 6.5, 7);
    }
}
static bool
_initialize_sml(Context *ctx)
{
    sml_set_stabilization_hits(ctx->sml, 0);
    sml_set_read_state_callback(ctx->sml, _read_state_cb, ctx);
    if (ctx->sml_engine == ANN_ENGINE)
        sml_ann_set_initial_required_observations(ctx->sml, REQUIRED_OBS);

    ctx->offense1 = _create_input(ctx, "red_striker");
    ctx->defense1 = _create_input(ctx, "red_goalkeeper");
    ctx->offense2 = _create_input(ctx, "yellow_striker");
    ctx->defense2 = _create_input(ctx, "yellow_goalkeeper");

    //number of the winner team
    ctx->winner = sml_new_output(ctx->sml, "winner");
    sml_variable_set_range(ctx->sml, ctx->winner, 0, 2);
    if (ctx->sml_engine == FUZZY_ENGINE) {
        sml_fuzzy_variable_add_term_ramp(ctx->sml, ctx->winner, "none",
            0 + DISCRETE_THRESHOLD, 0, 1);
        sml_fuzzy_variable_add_term_triangle(ctx->sml, ctx->winner,
            "red_winner", WINNER1 - DISCRETE_THRESHOLD, WINNER1,
            WINNER1 + DISCRETE_THRESHOLD, 1);
        sml_fuzzy_variable_add_term_ramp(ctx->sml, ctx->winner, "yellow_winner",
            WINNER2 - DISCRETE_THRESHOLD, WINNER2,
            1);
    }

    return true;
}
static struct sml_variable *
_create_input(Context *ctx, const char *name)
{
    char term_name[TERM_NAME_SIZE];
    struct sml_variable *v;
    uint16_t i;

    v = sml_new_input(ctx->sml, name);
    sml_variable_set_range(ctx->sml, v, 0, ctx->num_players - 1);

    if (ctx->sml_engine == FUZZY_ENGINE) {
        snprintf(term_name, LINE_SIZE, "%s_%s", name, ctx->players[0]);
        sml_fuzzy_variable_add_term_ramp(ctx->sml, v, term_name,
            0 + DISCRETE_THRESHOLD, 0, 1);
        for (i = 1; i < ctx->num_players - 1; i++) {
            snprintf(term_name, LINE_SIZE, "%s_%s", name, ctx->players[i]);
            sml_fuzzy_variable_add_term_triangle(ctx->sml, v, term_name,
                i - DISCRETE_THRESHOLD, i,
                i + DISCRETE_THRESHOLD, 1);
        }
        snprintf(term_name, LINE_SIZE, "%s_%s", name, ctx->players[i]);
        sml_fuzzy_variable_add_term_ramp(ctx->sml, v, term_name,
            ctx->num_players - 1 - DISCRETE_THRESHOLD,
            ctx->num_players - 1, 1);
    }

    return v;
}
static struct sml_variable *
_create_input(Context *ctx, const char *name)
{
    struct sml_variable *v;

    v = sml_new_input(ctx->sml, name);
    sml_variable_set_range(ctx->sml, v, 0, ctx->num_players - 1);
    sml_fuzzy_variable_set_default_term_width(ctx->sml, v, 1);
    sml_fuzzy_variable_set_is_id(ctx->sml, v, true);

    return v;
}
static Variable *
add_output(Context *ctx, const char *name, float min, float max)
{
    Variable *var = calloc(1, sizeof(Variable));

    strncpy(var->name, name, NAME_SIZE);
    var->name[NAME_SIZE - 1] = '\0';
    var->sml_var = sml_new_output(ctx->sml, name);
    var->min = min;
    var->max = max;
    sml_variable_set_range(ctx->sml, var->sml_var, min, max);
    ctx->outputs = g_list_append(ctx->outputs, var);
    return var;
}
static bool
_initialize_sml(Context *ctx)
{
    sml_set_stabilization_hits(ctx->sml, 0);
    sml_set_read_state_callback(ctx->sml, _read_state_cb, ctx);
    if (ctx->sml_engine == ANN_ENGINE)
        sml_ann_set_initial_required_observations(ctx->sml, REQUIRED_OBS);

    ctx->offense1 = _create_input(ctx, "red_striker");
    ctx->defense1 = _create_input(ctx, "red_goalkeeper");
    ctx->offense2 = _create_input(ctx, "yellow_striker");
    ctx->defense2 = _create_input(ctx, "yellow_goalkeeper");

    //number of the winner team
    ctx->winner = sml_new_output(ctx->sml, "winner");
    sml_variable_set_range(ctx->sml, ctx->winner, 0, 2);
    sml_fuzzy_variable_set_default_term_width(ctx->sml, ctx->winner, 1);
    sml_fuzzy_variable_set_is_id(ctx->sml, ctx->winner, true);

    return true;
}
Пример #8
0
int
main(int argc, char *argv[])
{
    unsigned int inputs, outputs, executions, num_terms;
    char strbuf[STRLEN];
    struct sml_variable *var;
    struct sml_object *sml;

    if (argc < 5) {
        fprintf(stderr, "Usage: %s <engine type (0 fuzzy, 1 ann)> <inputs> "
            "<outputs> <executions> <num_terms> <seed>\n", argv[0]);
        fprintf(stderr, "Fuzzy Test: %s 0 10 2 100 10\n", argv[0]);
        fprintf(stderr, "ANN Test: %s 1 10 2 100 10\n", argv[0]);
        return 1;
    }

    inputs = atoi(argv[2]);
    outputs = atoi(argv[3]);
    executions = atoi(argv[4]);
    num_terms = atoi(argv[5]);

    if (argc > 6)
        srand((unsigned int)atol(argv[6]));
    else
        srand(time(NULL));

    if (num_terms < 1) {
        fprintf(stderr, "num_terms must be a positive value\n");
        return 1;
    }

    sml = _sml_new(atoi(argv[1]));
    if (!sml) {
        fprintf(stderr, "Failed to create sml\n");
        return 1;
    }


    sml_set_read_state_callback(sml, _read_state_cb, &executions);
    sml_set_stabilization_hits(sml, 0);

    while (inputs) {
        snprintf(strbuf, STRLEN, "input%d", inputs);
        var = sml_new_input(sml, strbuf);
        sml_variable_set_range(sml, var, 0, RAND_MAX);
        _add_terms(sml, var, strbuf, inputs, num_terms);

        inputs--;
    }

    while (outputs) {
        snprintf(strbuf, STRLEN, "output%d", outputs);
        var = sml_new_output(sml, strbuf);
        sml_variable_set_range(sml, var, 0, RAND_MAX);
        _add_terms(sml, var, strbuf, outputs, num_terms);
        outputs--;
    }

    while (sml_process(sml) == 0) ;
    sml_free(sml);

    return 0;
}