Extract a user-facing target-achievement table from a Solution or
SolutionSet object returned by solve.
The returned table summarizes, for each stored target, the target level, the achieved value in the solution, the gap between achieved and required values, and whether the target was met.
Arguments
- x
A
SolutionorSolutionSetobject returned bysolve.- run
Optional positive integer giving the run index to extract from a
SolutionSet. IfNULL, all runs are returned when available.
Value
A simplified data.frame target summary, or NULL if the
solution does not contain targets. Typical columns include
feature, feature_name, target_level,
total_available, target, achieved, gap, and
met.
Details
Targets are optional in multiscape. If the solution object does not contain
a targets summary table at x$summary$targets, this function returns
NULL without error.
This function reads the stored targets summary and returns a simplified
user-facing table. If the summary contains achieved and
target_value, target satisfaction is evaluated as follows.
For lower-bound targets: $$ \mathrm{met} = (\mathrm{achieved} \ge \mathrm{target}), $$
and for upper-bound targets: $$ \mathrm{met} = (\mathrm{achieved} \le \mathrm{target}). $$
The interpretation of the target direction is taken from the sense
column when available:
"ge",">=", or"min"are treated as lower-bound targets,"le","<=", or"max"are treated as upper-bound targets,if
senseis missing, the target is treated as a lower bound by default.
The returned table is simplified and renames some internal fields for readability:
target_rawis returned astarget_level,basis_totalis returned astotal_available,target_valueis returned astarget.
If x is a SolutionSet and run is provided, only rows
belonging to that run are returned. If the result contains a run_id
column but only a single run is present and run was not requested
explicitly, the run_id column is removed for convenience.
The gap column is expected to be part of the stored summary. When
present, it typically represents:
$$
\mathrm{gap} = \mathrm{achieved} - \mathrm{target}.
$$
Examples
# \donttest{
if (requireNamespace("rcbc", quietly = TRUE)) {
pu_tbl <- data.frame(
id = 1:4,
cost = c(1, 2, 3, 4)
)
feat_tbl <- data.frame(
id = 1:2,
name = c("feature_1", "feature_2")
)
dist_feat_tbl <- data.frame(
pu = c(1, 1, 2, 3, 4),
feature = c(1, 2, 2, 1, 2),
amount = c(5, 2, 3, 4, 1)
)
actions_df <- data.frame(
id = "conservation",
name = "conservation"
)
effects_df <- data.frame(
pu = c(1, 2, 3, 4),
action = "conservation",
feature = c(1, 1, 2, 2),
benefit = c(2, 1, 1, 2),
loss = c(0, 0, 0, 0)
)
p <- create_problem(
pu = pu_tbl,
features = feat_tbl,
dist_features = dist_feat_tbl,
cost = "cost"
) |>
add_actions(actions_df, cost = 0) |>
add_effects(effects_df) |>
add_constraint_targets_relative(0.2) |>
add_objective_min_cost() |>
set_solver_cbc(time_limit = 10)
sol <- solve(p)
get_targets(sol)
}
#> feature feature_name target_level total_available target achieved gap met
#> 1 1 feature_1 0.2 9 1.8 2 0.2 TRUE
#> 2 2 feature_2 0.2 6 1.2 2 0.8 TRUE
# }
