From 8c2749af69cf4aac2685bf5220e058873800b5ff Mon Sep 17 00:00:00 2001 From: Nicola Di Cicco <93935338+nicoladicicco@users.noreply.github.com> Date: Wed, 21 Aug 2024 16:28:29 +0900 Subject: [PATCH 1/4] Update constraint descriptions --- src/constraints/all_different.jl | 2 +- src/constraints/all_equal.jl | 2 +- src/constraints/cardinality.jl | 7 +++---- src/constraints/channel.jl | 4 ++-- src/constraints/circuit.jl | 4 ++-- src/constraints/cumulative.jl | 4 ++-- src/constraints/element.jl | 4 ++-- src/constraints/extension.jl | 6 +++--- src/constraints/instantiation.jl | 4 ++-- src/constraints/intention.jl | 2 +- src/constraints/maximum.jl | 4 ++-- src/constraints/minimum.jl | 4 ++-- src/constraints/n_values.jl | 3 ++- src/constraints/no_overlap.jl | 6 +++--- src/constraints/ordered.jl | 2 +- src/constraints/sum.jl | 2 +- 16 files changed, 30 insertions(+), 30 deletions(-) diff --git a/src/constraints/all_different.jl b/src/constraints/all_different.jl index 3aa195f..c31f4a6 100644 --- a/src/constraints/all_different.jl +++ b/src/constraints/all_different.jl @@ -1,7 +1,7 @@ #!SECTION - all_different const description_all_different = """ -Global constraint ensuring that all the values of `x` are all different. +Global constraint ensuring that the values in `x` are all different. """ """ diff --git a/src/constraints/all_equal.jl b/src/constraints/all_equal.jl index 5509a49..a9b5af3 100644 --- a/src/constraints/all_equal.jl +++ b/src/constraints/all_equal.jl @@ -1,7 +1,7 @@ #!SECTION - all_equal const description_all_equal = """ -Global constraint ensuring that all the values of `x` are all equal. +Global constraint ensuring that the values in `x` are all equal. """ concept_all_equal(x, val) = all(y -> y == val, x) diff --git a/src/constraints/cardinality.jl b/src/constraints/cardinality.jl index 6374f9a..635805c 100644 --- a/src/constraints/cardinality.jl +++ b/src/constraints/cardinality.jl @@ -1,14 +1,13 @@ # cardinality (or global_cardinality or gcc) const description_cardinality = """ -The cardinality constraint, also known as the global cardinality constraint (GCC), is a constraint in constraint programming that restricts the number of times a value can appear in a set of variables. +Global constraint that restricts the number of times specific values in a list `values` can appear in `x`. """ const description_cardinality_closed = """ -The closed cardinality constraint, also known as the global cardinality constraint (GCC), is a constraint in constraint programming that restricts the number of times a value can appear in a set of variables. It is closed, meaning that all values in the domain of the variables must be considered. +Global constraint that restricts the number of times in a list `values` can appear in `x`. It is closed, meaning that the variables in `x` cannot have values outside the ones in `list`. """ - const description_cardinality_open = """ -The open cardinality constraint, also known as the global cardinality constraint (GCC), is a constraint in constraint programming that restricts the number of times a value can appear in a set of variables. It is open, meaning that only the values in the list of values must be considered. +Global constraint that restricts the number of times in a list `values` can appear in `x`. It is open, meaning that the variables in `x` can have values outside the ones in `list`. """ """ diff --git a/src/constraints/channel.jl b/src/constraints/channel.jl index 41102b7..ab1bd5a 100644 --- a/src/constraints/channel.jl +++ b/src/constraints/channel.jl @@ -1,11 +1,11 @@ const description_channel = """ -The channel constraint establishes a bijective correspondence between two sets of variables. This means that each value in the first set of variables corresponds to a unique value in the second set, and vice versa. +Ensures that if the i-th element of `x` is assigned the value j, then the j-th element of `x` must be assigned the value i. """ """ xcsp_channel(; list) -Return `true` if the channel constraint is satisfied, `false` otherwise. The channel constraint establishes a bijective correspondence between two sets of variables. This means that each value in the first set of variables corresponds to a unique value in the second set, and vice versa. +Return `true` if the channel constraint is satisfied, `false` otherwise. The channel constraint ensures that if the i-th element of `list` is assigned the value j, then the j-th element of `list` must be assigned the value i. ## Arguments - `list::Union{AbstractVector, Tuple}`: list of values to check. diff --git a/src/constraints/circuit.jl b/src/constraints/circuit.jl index a750dff..1abb817 100644 --- a/src/constraints/circuit.jl +++ b/src/constraints/circuit.jl @@ -1,11 +1,11 @@ const description_circuit = """ -The circuit constraint is a global constraint used in constraint programming, often in routing problems. It ensures that the values of a list of variables form a circuit, i.e., a sequence where each value is the index of the next value in the sequence, and the sequence eventually loops back to the start. +Global constraint ensuring that the values of `x` form a circuit, i.e., a sequence where each value is the index of the next value in the sequence, and the sequence eventually loops back to the start. Often used for routing problems. """ """ xcsp_circuit(; list, size) -Return `true` if the circuit constraint is satisfied, `false` otherwise. The circuit constraint is a global constraint used in constraint programming, often in routing problems. It ensures that the values of a list of variables form a circuit, i.e., a sequence where each value is the index of the next value in the sequence, and the sequence eventually loops back to the start. +Return `true` if the circuit constraint is satisfied, `false` otherwise. The circuit constraint is a global constraint ensuring that the values of a list of variables form a circuit, i.e., a sequence where each value is the index of the next value in the sequence, and the sequence eventually loops back to the start. ## Arguments - `list::AbstractVector`: list of values to check. diff --git a/src/constraints/cumulative.jl b/src/constraints/cumulative.jl index a80faa3..7d2c584 100644 --- a/src/constraints/cumulative.jl +++ b/src/constraints/cumulative.jl @@ -1,11 +1,11 @@ const description_cumulative = """ -The cumulative constraint is a global constraint used in constraint programming that is often used in scheduling problems. It ensures that for any point in time, the sum of the "heights" of tasks that are ongoing at that time does not exceed a certain limit. +Global constraint ensuring that for any point in time, the sum of the "heights" of tasks that are ongoing at that time does not exceed a certain limit. Often used in scheduling problems """ """ xcsp_cumulative(; origins, lengths, heights, condition) -Return `true` if the cumulative constraint is satisfied, `false` otherwise. The cumulative constraint is a global constraint used in constraint programming that is often used in scheduling problems. It ensures that for any point in time, the sum of the "heights" of tasks that are ongoing at that time does not exceed a certain limit. +Return `true` if the cumulative constraint is satisfied, `false` otherwise. The cumulative constraint is a global constraint ensuring that for any point in time, the sum of the "heights" of tasks that are ongoing at that time does not exceed a certain limit. ## Arguments - `origins::AbstractVector`: list of origins of the tasks. diff --git a/src/constraints/element.jl b/src/constraints/element.jl index 8a681a3..79e1640 100644 --- a/src/constraints/element.jl +++ b/src/constraints/element.jl @@ -1,11 +1,11 @@ const description_element = """ -The element constraint is a global constraint used in constraint programming that specifies that the value of a variable should be equal to the value of another variable indexed by a third variable. +Global constraint specifying that a variable in `x` indexed by `id` should be equal to a `value`. """ """ xcsp_element(; list, index, condition) -Return `true` if the element constraint is satisfied, `false` otherwise. The element constraint is a global constraint used in constraint programming that specifies that the value of a variable should be equal to the value of another variable indexed by a third variable. +Return `true` if the element constraint is satisfied, `false` otherwise. The element constraint is a global constraint specifying that a variable in `x` indexed by `id` should be equal to a `value`. ## Arguments - `list::Union{AbstractVector, Tuple}`: list of values to check. diff --git a/src/constraints/extension.jl b/src/constraints/extension.jl index 7b0e276..0dc9135 100644 --- a/src/constraints/extension.jl +++ b/src/constraints/extension.jl @@ -3,15 +3,15 @@ # TODO - Better input for conflicts and supports (cf XCSP3-core) const description_extension = """ -Global constraint enforcing that the tuple `x` matches a configuration within the supports set `pair_vars[1]` or does not match any configuration within the conflicts set `pair_vars[2]`. It embodies the logic: `x ∈ pair_vars[1] || x ∉ pair_vars[2]`, providing a comprehensive way to define valid (supported) and invalid (conflicted) tuples for constraint satisfaction problems. This constraint is versatile, allowing for the explicit delineation of both acceptable and unacceptable configurations. +Global constraint enforcing that `x` matches a configuration within the supports set `pair_vars[1]` or does not match any configuration within the conflicts set `pair_vars[2]`. It embodies the logic: `x ∈ pair_vars[1] || x ∉ pair_vars[2]`, providing a comprehensive way to define valid (supported) and invalid (conflicted) configurations for constraint satisfaction problems. """ const description_supports = """ -Global constraint ensuring that the tuple `x` matches a configuration listed within the support set `pair_vars`. This constraint is derived from the extension model, specifying that `x` must be one of the explicitly defined supported configurations: `x ∈ pair_vars`. It is utilized to directly declare the tuples that are valid and should be included in the solution space. +Global constraint ensuring that `x` matches a configuration listed within the support set `pair_vars`. This constraint is derived from the extension model, specifying that `x` must be one of the explicitly defined supported configurations: `x ∈ pair_vars`. It is utilized to directly declare the configurations that are valid and should be included in the solution space. """ const description_conflicts = """ -Global constraint ensuring that the tuple `x` does not match any configuration listed within the conflict set `pair_vars`. This constraint, originating from the extension model, stipulates that `x` must avoid all configurations defined as conflicts: `x ∉ pair_vars`. It is useful for specifying tuples that are explicitly forbidden and should be excluded from the solution space. +Global constraint ensuring that `x` does not match any configuration listed within the conflict set `pair_vars`. This constraint, originating from the extension model, stipulates that `x` must avoid all configurations defined as conflicts: `x ∉ pair_vars`. It is useful for specifying configurations that are explicitly forbidden and should be excluded from the solution space. """ xcsp_extension(list, ::Nothing, conflicts) = list ∉ conflicts diff --git a/src/constraints/instantiation.jl b/src/constraints/instantiation.jl index c29be0c..9319188 100644 --- a/src/constraints/instantiation.jl +++ b/src/constraints/instantiation.jl @@ -1,11 +1,11 @@ const description_instantiation = """ -The instantiation constraint is a global constraint used in constraint programming that ensures that a list of variables takes on a specific set of values in a specific order. +Global constraint ensuring that `x` takes on a specific set of `values` in a specific order. """ """ xcsp_instantiation(; list, values) -Return `true` if the instantiation constraint is satisfied, `false` otherwise. The instantiation constraint is a global constraint used in constraint programming that ensures that a list of variables takes on a specific set of values in a specific order. +Return `true` if the instantiation constraint is satisfied, `false` otherwise. The instantiation constraint is a global constraint ensuring that `x` takes on a specific set of `values` in a specific order. ## Arguments - `list::AbstractVector`: list of values to check. diff --git a/src/constraints/intention.jl b/src/constraints/intention.jl index 4494140..36d7388 100644 --- a/src/constraints/intention.jl +++ b/src/constraints/intention.jl @@ -3,7 +3,7 @@ # TODO - Add a DSL for intension (cf XCSP3-core) const description_dist_different = """ -A constraint ensuring that the distances between marks on the ruler are unique. Specifically, it checks that the distance between `x[1]` and `x[2]`, and the distance between `x[3]` and `x[4]`, are different. This constraint is fundamental in ensuring the validity of a Golomb ruler, where no two pairs of marks should have the same distance between them. +Given a 4-dimensional vector `x`, ensures that the absolute difference between `x[1]` and `x[2]`, and between `x[3]` and `x[4]`, are different. This constraint is fundamental in ensuring the validity of a Golomb ruler, where no two pairs of marks should have the same distance between them. """ """ diff --git a/src/constraints/maximum.jl b/src/constraints/maximum.jl index fba4278..dcc9635 100644 --- a/src/constraints/maximum.jl +++ b/src/constraints/maximum.jl @@ -1,11 +1,11 @@ const description_maximum = """ -The maximum constraint is a global constraint used in constraint programming that specifies that a certain condition should hold for the maximum value in a list of variables. +Global constraint ensuring that a certain numerical condition holds for the maximum value in `x`. """ """ xcsp_maximum(; list, condition) -Return `true` if the maximum constraint is satisfied, `false` otherwise. The maximum constraint is a global constraint used in constraint programming that specifies that a certain condition should hold for the maximum value in a list of variables. +Return `true` if the maximum constraint is satisfied, `false` otherwise. The maximum constraint is a global constraint specifying that a certain condition should hold for the maximum value in a list of variables. ## Arguments - `list::Union{AbstractVector, Tuple}`: list of values to check. diff --git a/src/constraints/minimum.jl b/src/constraints/minimum.jl index e70320b..23436ff 100644 --- a/src/constraints/minimum.jl +++ b/src/constraints/minimum.jl @@ -1,11 +1,11 @@ const description_minimum = """ -The minimum constraint is a global constraint used in constraint programming that specifies that a certain condition should hold for the minimum value in a list of variables. +Global constraint specifying that a certain numerical condition should hold for the minimum value in `x`. """ """ xcsp_minimum(; list, condition) -Return `true` if the minimum constraint is satisfied, `false` otherwise. The minimum constraint is a global constraint used in constraint programming that specifies that a certain condition should hold for the minimum value in a list of variables. +Return `true` if the minimum constraint is satisfied, `false` otherwise. The minimum constraint is a global constraint specifying that a certain condition should hold for the minimum value in a list of variables. ## Arguments - `list::Union{AbstractVector, Tuple}`: list of values to check. diff --git a/src/constraints/n_values.jl b/src/constraints/n_values.jl index ad45f3a..6f48d5c 100644 --- a/src/constraints/n_values.jl +++ b/src/constraints/n_values.jl @@ -1,7 +1,8 @@ #!SECTION - nValues const description_nvalues = """ -The nValues constraint specifies that the number of distinct values in the list of variables x is equal to a given value. The constraint is defined by the following expression: nValues(x, op, val) where x is a list of variables, op is a comparison operator, and val is an integer value. +Ensures that the number of distinct values in `x` satisfies a given numerical condition. +The constraint is defined by the following expression: `nValues(x, op, val)` where `x` is a list of variables, `op` is a comparison operator, and `val` is an integer value. """ """ diff --git a/src/constraints/no_overlap.jl b/src/constraints/no_overlap.jl index 0904aaf..f8dbe07 100644 --- a/src/constraints/no_overlap.jl +++ b/src/constraints/no_overlap.jl @@ -1,13 +1,13 @@ const description_no_overlap = """ -The no_overlap constraint is a global constraint used in constraint programming, often in scheduling problems. It ensures that tasks do not overlap in time, i.e., for any two tasks, either the first task finishes before the second task starts, or the second task finishes before the first task starts. +Global constraint operating on a set of tasks, defined by `origin` (starting times), and `length`. This constraint ensures that tasks do not overlap in time, i.e., for any two tasks, either the first task finishes before the second task starts, or the second task finishes before the first task starts. Often used in scheduling problems. """ const description_no_overlap_no_zero = """ -The no_overlap constraint is a global constraint used in constraint programming, often in scheduling problems. It ensures that tasks do not overlap in time, i.e., for any two tasks, either the first task finishes before the second task starts, or the second task finishes before the first task starts. This variant ignores zero-length tasks. +Global constraint operating on a set of tasks, defined by `origin` (starting times), and `length`. This constraint ensures that tasks do not overlap in time, i.e., for any two tasks, either the first task finishes before the second task starts, or the second task finishes before the first task starts. This variant ignores zero-length tasks. Often used in scheduling problems. """ const description_no_overlap_with_zero = """ -The no_overlap constraint is a global constraint used in constraint programming, often in scheduling problems. It ensures that tasks do not overlap in time, i.e., for any two tasks, either the first task finishes before the second task starts, or the second task finishes before the first task starts. This variant includes zero-length tasks. +Global constraint operating on a set of tasks, defined by `origin` (starting times), and `length`. This constraint ensures that tasks do not overlap in time, i.e., for any two tasks, either the first task finishes before the second task starts, or the second task finishes before the first task starts. This variant includes zero-length tasks. Often used in scheduling problems. """ """ diff --git a/src/constraints/ordered.jl b/src/constraints/ordered.jl index d5aba48..bfb00a2 100644 --- a/src/constraints/ordered.jl +++ b/src/constraints/ordered.jl @@ -1,5 +1,5 @@ const description_ordered = """ -Global constraint ensuring that all the values of `x` are in an increasing order. +Global constraint ensuring that all the values of `x` are in a total order defined by a comparison operator. """ const description_increasing = """ diff --git a/src/constraints/sum.jl b/src/constraints/sum.jl index 0c393ee..c35d677 100644 --- a/src/constraints/sum.jl +++ b/src/constraints/sum.jl @@ -1,5 +1,5 @@ const description_sum = """ -Global constraint ensuring that the sum of the variables in `x` satisfies a given condition. +Global constraint ensuring that the sum of the variables in `x` satisfies a given numerical condition. """ """ From a629f154f4432cca64f7185ef340f4133da02271 Mon Sep 17 00:00:00 2001 From: Nicola Di Cicco <93935338+nicoladicicco@users.noreply.github.com> Date: Wed, 21 Aug 2024 16:41:54 +0900 Subject: [PATCH 2/4] Small fix --- src/constraints/circuit.jl | 2 +- src/constraints/minimum.jl | 2 +- 2 files changed, 2 insertions(+), 2 deletions(-) diff --git a/src/constraints/circuit.jl b/src/constraints/circuit.jl index 1abb817..6fe37ff 100644 --- a/src/constraints/circuit.jl +++ b/src/constraints/circuit.jl @@ -5,7 +5,7 @@ Global constraint ensuring that the values of `x` form a circuit, i.e., a sequen """ xcsp_circuit(; list, size) -Return `true` if the circuit constraint is satisfied, `false` otherwise. The circuit constraint is a global constraint ensuring that the values of a list of variables form a circuit, i.e., a sequence where each value is the index of the next value in the sequence, and the sequence eventually loops back to the start. +Return `true` if the circuit constraint is satisfied, `false` otherwise. The circuit constraint is a global constraint ensuring that the values of `x` form a circuit, i.e., a sequence where each value is the index of the next value in the sequence, and the sequence eventually loops back to the start. ## Arguments - `list::AbstractVector`: list of values to check. diff --git a/src/constraints/minimum.jl b/src/constraints/minimum.jl index 23436ff..67a694e 100644 --- a/src/constraints/minimum.jl +++ b/src/constraints/minimum.jl @@ -1,5 +1,5 @@ const description_minimum = """ -Global constraint specifying that a certain numerical condition should hold for the minimum value in `x`. +Global constraint ensuring that a certain numerical condition holds for the minimum value in `x`. """ """ From 4b199d927d218db1669930869d324cde7e6902de Mon Sep 17 00:00:00 2001 From: Nicola Di Cicco <93935338+nicoladicicco@users.noreply.github.com> Date: Wed, 21 Aug 2024 16:42:36 +0900 Subject: [PATCH 3/4] Small fix --- src/constraints/cumulative.jl | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/src/constraints/cumulative.jl b/src/constraints/cumulative.jl index 7d2c584..40ba690 100644 --- a/src/constraints/cumulative.jl +++ b/src/constraints/cumulative.jl @@ -1,11 +1,11 @@ const description_cumulative = """ -Global constraint ensuring that for any point in time, the sum of the "heights" of tasks that are ongoing at that time does not exceed a certain limit. Often used in scheduling problems +Global constraint operating on a set of tasks, defined by `origin` (starting times), `length`, and `height`. This constraint ensures that, at each point in time, the sum of the `height` of tasks that overlap that point, respects a numerical condition. """ """ xcsp_cumulative(; origins, lengths, heights, condition) -Return `true` if the cumulative constraint is satisfied, `false` otherwise. The cumulative constraint is a global constraint ensuring that for any point in time, the sum of the "heights" of tasks that are ongoing at that time does not exceed a certain limit. +Return `true` if the cumulative constraint is satisfied, `false` otherwise. The cumulative constraint is a global constraint operating on a set of tasks, defined by `origin` (starting times), `length`, and `height`. This constraint ensures that, at each point in time, the sum of the `height` of tasks that overlap that point, respects a numerical condition. ## Arguments - `origins::AbstractVector`: list of origins of the tasks. From 38cecf6bb102ae1f41f9c7f4c5bbcef5b7f7fa8c Mon Sep 17 00:00:00 2001 From: Jean-Francois Baffier Date: Tue, 10 Sep 2024 15:40:51 +0900 Subject: [PATCH 4/4] Update Project.toml --- Project.toml | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/Project.toml b/Project.toml index 45127d2..f31e178 100644 --- a/Project.toml +++ b/Project.toml @@ -1,7 +1,7 @@ name = "Constraints" uuid = "30f324ab-b02d-43f0-b619-e131c61659f7" authors = ["Jean-François Baffier"] -version = "0.5.7" +version = "0.5.8" [deps] CompositionalNetworks = "4b67e4b5-442d-4ef5-b760-3f5df3a57537"