Clingo C API
C API for clingo providing high level functions to control grounding and solving.
Loading...
Searching...
No Matches
statistics.c

The example shows how to inspect statistics.

The example shows how to inspect statistics.

Output

./statistics 0
Model: a
Model: b
problem:
lp:
atoms:
2
atoms_aux:
0
...
solving:
...
summary:
...
accu:
times:
...
models:
...
solving:
...

Code

#include <clingo.h>
#include <stdio.h>
#include <stdlib.h>
bool print_model(clingo_model_t const *model) {
bool ret = true;
clingo_symbol_t *atoms = NULL;
size_t atoms_n;
clingo_symbol_t const *it, *ie;
char *str = NULL;
size_t str_n = 0;
// determine the number of (shown) symbols in the model
goto error;
}
// allocate required memory to hold all the symbols
if (!(atoms = (clingo_symbol_t *)malloc(sizeof(*atoms) * atoms_n))) {
clingo_set_error(clingo_error_bad_alloc, "could not allocate memory for atoms");
goto error;
}
// retrieve the symbols in the model
if (!clingo_model_symbols(model, clingo_show_type_shown, atoms, atoms_n)) {
goto error;
}
printf("Model:");
for (it = atoms, ie = atoms + atoms_n; it != ie; ++it) {
size_t n;
char *str_new;
// determine size of the string representation of the next symbol in the model
goto error;
}
if (str_n < n) {
// allocate required memory to hold the symbol's string
if (!(str_new = (char *)realloc(str, sizeof(*str) * n))) {
clingo_set_error(clingo_error_bad_alloc, "could not allocate memory for symbol's string");
goto error;
}
str = str_new;
str_n = n;
}
// retrieve the symbol's string
if (!clingo_symbol_to_string(*it, str, n)) {
goto error;
}
printf(" %s", str);
}
printf("\n");
goto out;
error:
ret = false;
out:
if (atoms) {
free(atoms);
}
if (str) {
free(str);
}
return ret;
}
bool event_handler(clingo_solve_event_type_t type, void *event, void *data, bool *goon) {
(void)data;
(void)goon;
switch (type) {
uint64_t root, values, summary, value;
uint16_t n = 10, random = 1;
double sum = 0;
// obtain a pointer to the accumulated statistics
stats = ((clingo_statistics_t **)event)[1];
// get the root key which refering to a special modifiable entry
if (!clingo_statistics_root(stats, &root)) {
return false;
}
// set some pseudo-random values in an array
if (!clingo_statistics_map_add_subkey(stats, root, "values", clingo_statistics_type_array, &values)) {
return false;
}
for (uint16_t i = 0; i < n; ++i) {
random = (random << 3) ^ (random ^ ((random & 0xf800) >> 13)) ^ i;
return false;
}
if (!clingo_statistics_value_set(stats, value, random)) {
return false;
}
sum += random;
}
// add the sum and average of the values in a map under key summary
if (!clingo_statistics_map_add_subkey(stats, root, "summary", clingo_statistics_type_map, &summary)) {
return false;
}
if (!clingo_statistics_map_add_subkey(stats, summary, "sum", clingo_statistics_type_value, &value)) {
return false;
}
if (!clingo_statistics_value_set(stats, value, sum)) {
return false;
}
if (!clingo_statistics_map_add_subkey(stats, summary, "avg", clingo_statistics_type_value, &value)) {
return false;
}
if (!clingo_statistics_value_set(stats, value, (double)sum / n)) {
return false;
}
break;
}
}
return true;
}
bool ret = true;
clingo_model_t const *model;
// get a solve handle
if (!clingo_control_solve(ctl, clingo_solve_mode_yield, NULL, 0, event_handler, NULL, &handle)) {
goto error;
}
// loop over all models
while (true) {
goto error;
}
if (!clingo_solve_handle_model(handle, &model)) {
goto error;
}
// print the model
if (model) {
print_model(model);
}
// stop if there are no more models
else {
break;
}
}
// get the solve results
if (!clingo_solve_handle_get(handle, result)) {
goto error;
}
goto out;
error:
ret = false;
out:
// free the solve handle
return clingo_solve_handle_close(handle) && ret;
}
void print_prefix(int depth) {
for (int i = 0; i < depth; ++i) {
printf(" ");
}
}
// recursively print the statistics object
bool print_statistics(const clingo_statistics_t *stats, uint64_t key, int depth) {
bool ret = true;
// get the type of an entry and switch over its various values
if (!clingo_statistics_type(stats, key, &type)) {
goto error;
}
switch ((enum clingo_statistics_type_e)type) {
// print values
double value;
// print value (with prefix for readability)
print_prefix(depth);
if (!clingo_statistics_value_get(stats, key, &value)) {
goto error;
}
printf("%g\n", value);
break;
}
// print arrays
size_t size;
// loop over array elements
if (!clingo_statistics_array_size(stats, key, &size)) {
goto error;
}
for (size_t i = 0; i < size; ++i) {
uint64_t subkey;
// print array offset (with prefix for readability)
if (!clingo_statistics_array_at(stats, key, i, &subkey)) {
goto error;
}
print_prefix(depth);
printf("%zu:\n", i);
// recursively print subentry
if (!print_statistics(stats, subkey, depth + 1)) {
goto error;
}
}
break;
}
// print maps
size_t size;
// loop over map elements
if (!clingo_statistics_map_size(stats, key, &size)) {
goto error;
}
for (size_t i = 0; i < size; ++i) {
char const *name;
uint64_t subkey;
// get and print map name (with prefix for readability)
if (!clingo_statistics_map_subkey_name(stats, key, i, &name)) {
goto error;
}
if (!clingo_statistics_map_at(stats, key, name, &subkey)) {
goto error;
}
print_prefix(depth);
printf("%s:\n", name);
// recursively print subentry
if (!print_statistics(stats, subkey, depth + 1)) {
goto error;
}
}
}
// this case won't occur if the statistics are traversed like this
goto out;
}
}
goto out;
error:
ret = false;
out:
return ret;
}
int main(int argc, char const **argv) {
char const *error_message;
int ret = 0;
clingo_control_t *ctl = NULL;
clingo_part_t parts[] = {{"base", NULL, 0}};
clingo_id_t conf_root, conf_sub;
const clingo_statistics_t *stats;
uint64_t stats_key;
// create a control object and pass command line arguments
if (!clingo_control_new(argv + 1, argc - 1, NULL, NULL, 20, &ctl)) {
goto error;
}
// get the configuration object and its root key
if (!clingo_control_configuration(ctl, &conf)) {
goto error;
}
if (!clingo_configuration_root(conf, &conf_root)) {
goto error;
}
// and set the statistics level to one to get more statistics
if (!clingo_configuration_map_at(conf, conf_root, "stats", &conf_sub)) {
goto error;
}
if (!clingo_configuration_value_set(conf, conf_sub, "1")) {
goto error;
}
// add a logic program to the base part
if (!clingo_control_add(ctl, "base", NULL, 0, "a :- not b. b :- not a.")) {
goto error;
}
// ground the base part
if (!clingo_control_ground(ctl, parts, 1, NULL, NULL)) {
goto error;
}
// solve
if (!solve(ctl, &solve_ret)) {
goto error;
}
// get the statistics object, get the root key, then print the statistics recursively
if (!clingo_control_statistics(ctl, &stats)) {
goto error;
}
if (!clingo_statistics_root(stats, &stats_key)) {
goto error;
}
if (!print_statistics(stats, stats_key, 0)) {
goto error;
}
goto out;
error:
if (!(error_message = clingo_error_message())) {
error_message = "error";
}
printf("%s\n", error_message);
out:
if (ctl) {
}
return ret;
}
Single header containing the whole clingo API.
CLINGO_VISIBILITY_DEFAULT char const * clingo_error_message()
Get the last error message set if an API call fails.
CLINGO_VISIBILITY_DEFAULT void clingo_set_error(clingo_error_t code, char const *message)
Set a custom error code and message in the active thread.
CLINGO_VISIBILITY_DEFAULT clingo_error_t clingo_error_code()
Get the last error code set by a clingo API call.
uint32_t clingo_id_t
Unsigned integer type used in various places.
Definition clingo.h:125
@ clingo_error_bad_alloc
memory could not be allocated
Definition clingo.h:144
CLINGO_VISIBILITY_DEFAULT bool clingo_configuration_map_at(clingo_configuration_t const *configuration, clingo_id_t key, char const *name, clingo_id_t *subkey)
Lookup a subkey under the given name.
CLINGO_VISIBILITY_DEFAULT bool clingo_configuration_root(clingo_configuration_t const *configuration, clingo_id_t *key)
Get the root key of the configuration.
CLINGO_VISIBILITY_DEFAULT bool clingo_statistics_array_at(clingo_statistics_t const *statistics, uint64_t key, size_t offset, uint64_t *subkey)
Get the subkey at the given offset of an array entry.
CLINGO_VISIBILITY_DEFAULT bool clingo_statistics_map_at(clingo_statistics_t const *statistics, uint64_t key, char const *name, uint64_t *subkey)
Lookup a subkey under the given name.
CLINGO_VISIBILITY_DEFAULT bool clingo_statistics_map_add_subkey(clingo_statistics_t *statistics, uint64_t key, char const *name, clingo_statistics_type_t type, uint64_t *subkey)
Add a subkey with the given name.
CLINGO_VISIBILITY_DEFAULT bool clingo_statistics_map_size(clingo_statistics_t const *statistics, uint64_t key, size_t *size)
Get the number of subkeys of a map entry.
CLINGO_VISIBILITY_DEFAULT bool clingo_statistics_array_push(clingo_statistics_t *statistics, uint64_t key, clingo_statistics_type_t type, uint64_t *subkey)
Create the subkey at the end of an array entry.
struct clingo_configuration clingo_configuration_t
Handle for to the solver configuration.
Definition clingo.h:1915
CLINGO_VISIBILITY_DEFAULT bool clingo_configuration_value_set(clingo_configuration_t *configuration, clingo_id_t key, char const *value)
Set the value of an entry.
CLINGO_VISIBILITY_DEFAULT bool clingo_statistics_array_size(clingo_statistics_t const *statistics, uint64_t key, size_t *size)
Get the size of an array entry.
CLINGO_VISIBILITY_DEFAULT bool clingo_statistics_map_subkey_name(clingo_statistics_t const *statistics, uint64_t key, size_t offset, char const **name)
Get the name associated with the offset-th subkey.
CLINGO_VISIBILITY_DEFAULT bool clingo_control_statistics(clingo_control_t const *control, clingo_statistics_t const **statistics)
Get a statistics object to inspect solver statistics.
CLINGO_VISIBILITY_DEFAULT bool clingo_control_solve(clingo_control_t *control, clingo_solve_mode_bitset_t mode, clingo_literal_t const *assumptions, size_t assumptions_size, clingo_solve_event_callback_t notify, void *data, clingo_solve_handle_t **handle)
Solve the currently grounded logic program enumerating its models.
CLINGO_VISIBILITY_DEFAULT bool clingo_control_configuration(clingo_control_t *control, clingo_configuration_t **configuration)
Get a configuration object to change the solver configuration.
unsigned clingo_solve_result_bitset_t
Corresponding type to clingo_solve_result_e.
Definition clingo.h:2488
CLINGO_VISIBILITY_DEFAULT bool clingo_control_new(char const *const *arguments, size_t arguments_size, clingo_logger_t logger, void *logger_data, unsigned message_limit, clingo_control_t **control)
Create a new control object.
CLINGO_VISIBILITY_DEFAULT void clingo_control_free(clingo_control_t *control)
Free a control object created with clingo_control_new().
CLINGO_VISIBILITY_DEFAULT bool clingo_control_add(clingo_control_t *control, char const *name, char const *const *parameters, size_t parameters_size, char const *program)
Extend the logic program with the given non-ground logic program in string form.
struct clingo_control clingo_control_t
Control object holding grounding and solving state.
Definition clingo.h:2973
CLINGO_VISIBILITY_DEFAULT bool clingo_control_ground(clingo_control_t *control, clingo_part_t const *parts, size_t parts_size, clingo_ground_callback_t ground_callback, void *ground_callback_data)
Ground the selected parts of the current (non-ground) logic program.
CLINGO_VISIBILITY_DEFAULT bool clingo_model_symbols(clingo_model_t const *model, clingo_show_type_bitset_t show, clingo_symbol_t *symbols, size_t size)
Get the symbols of the selected types in the model.
CLINGO_VISIBILITY_DEFAULT bool clingo_model_symbols_size(clingo_model_t const *model, clingo_show_type_bitset_t show, size_t *size)
Get the number of symbols of the selected types in the model.
struct clingo_model clingo_model_t
Object representing a model.
Definition clingo.h:2280
@ clingo_show_type_shown
Select shown atoms and terms.
Definition clingo.h:2293
struct clingo_solve_handle clingo_solve_handle_t
Search handle to a solve call.
Definition clingo.h:2564
unsigned clingo_solve_event_type_t
Corresponding type to clingo_solve_event_type_e.
Definition clingo.h:2541
CLINGO_VISIBILITY_DEFAULT bool clingo_solve_handle_close(clingo_solve_handle_t *handle)
Stops the running search and releases the handle.
CLINGO_VISIBILITY_DEFAULT bool clingo_solve_handle_resume(clingo_solve_handle_t *handle)
Discards the last model and starts the search for the next one.
CLINGO_VISIBILITY_DEFAULT bool clingo_solve_handle_get(clingo_solve_handle_t *handle, clingo_solve_result_bitset_t *result)
Get the next solve result.
CLINGO_VISIBILITY_DEFAULT bool clingo_solve_handle_model(clingo_solve_handle_t *handle, clingo_model_t const **model)
Get the next model (or zero if there are no more models).
@ clingo_solve_mode_yield
Yield models in calls to clingo_solve_handle_model.
Definition clingo.h:2528
@ clingo_solve_event_type_statistics
Issued when the statistics can be updated.
Definition clingo.h:2537
CLINGO_VISIBILITY_DEFAULT bool clingo_statistics_value_set(clingo_statistics_t *statistics, uint64_t key, double value)
Set the value of the given entry.
int clingo_statistics_type_t
Corresponding type to clingo_statistics_type.
Definition clingo.h:2109
CLINGO_VISIBILITY_DEFAULT bool clingo_statistics_root(clingo_statistics_t const *statistics, uint64_t *key)
Get the root key of the statistics.
clingo_statistics_type_e
Enumeration for entries of the statistics.
Definition clingo.h:2102
CLINGO_VISIBILITY_DEFAULT bool clingo_statistics_value_get(clingo_statistics_t const *statistics, uint64_t key, double *value)
Get the value of the given entry.
struct clingo_statistic clingo_statistics_t
Handle for the solver statistics.
Definition clingo.h:2112
CLINGO_VISIBILITY_DEFAULT bool clingo_statistics_type(clingo_statistics_t const *statistics, uint64_t key, clingo_statistics_type_t *type)
Get the type of a key.
@ clingo_statistics_type_map
the entry is a map
Definition clingo.h:2106
@ clingo_statistics_type_array
the entry is an array
Definition clingo.h:2105
@ clingo_statistics_type_empty
the entry is invalid (has neither of the types below)
Definition clingo.h:2103
@ clingo_statistics_type_value
the entry is a (double) value
Definition clingo.h:2104
CLINGO_VISIBILITY_DEFAULT bool clingo_symbol_to_string_size(clingo_symbol_t symbol, size_t *size)
Get the size of the string representation of a symbol (including the terminating 0).
uint64_t clingo_symbol_t
Represents a symbol.
Definition clingo.h:330
CLINGO_VISIBILITY_DEFAULT bool clingo_symbol_to_string(clingo_symbol_t symbol, char *string, size_t size)
Get the string representation of a symbol.
Struct used to specify the program parts that have to be grounded.
Definition clingo.h:2908