Science Score: 67.0%
This score indicates how likely this project is to be science-related based on various indicators:
-
✓CITATION.cff file
Found CITATION.cff file -
✓codemeta.json file
Found codemeta.json file -
✓.zenodo.json file
Found .zenodo.json file -
✓DOI references
Found 2 DOI reference(s) in README -
✓Academic publication links
Links to: arxiv.org -
○Academic email domains
-
○Institutional organization owner
-
○JOSS paper metadata
-
○Scientific vocabulary similarity
Low similarity (11.5%) to scientific vocabulary
Repository
Algorithms for fair item allocation.
Basic Info
Statistics
- Stars: 1
- Watchers: 1
- Forks: 1
- Open Issues: 0
- Releases: 2
Metadata Files
README.md
Allocations.jl
The Allocations package deals with the fair allocation of indivisible items to a set of agents. For some background on this topic, see, e.g., the Wikipedia entry on fair item allocation, or the surveys by Amanatidis et al. and Suksompong, on the unconstrained and constrained versions of the problem, respectively.
Installation
To install the package, you can simply import it in the Julia REPL:
julia> using Allocations
Press enter at the resulting prompt to install both the package and its dependencies.
To install a more recent version than the released one, you can use the package
manager directly. In the Julia REPL, press ] to enter the Pkg REPL, and then
add the package directly from the source:
pkg> add https://github.com/mlhetland/Allocations.jl
You can then import the module as before.
Basic use
To specify an allocation problem instance, create a valuation profile:
julia> V = Profile([1 2 3; 2 3 1])
Additive{Matrix{Int64}} with 2 agents and 3 items:
1 2 3
2 3 1
Profile is an abstract class, and Profile(X::Matrix) is an alias for
Additive(X). Once you have a valuation profile, you can use an allocation
function (ones called alloc_...), e.g., for finding a maximum Nash welfare
(MNW) allocation:
julia> res = alloc_mnw(V);
Note that the first time you call an allocation function, it may take some time to finish, because there's quite a lot of compilation going on behind the scenes. From then on, in the same REPL session, there will be much less overhead.
These functions take a Profile as input and return a named tuple with the
field alloc referring to an Allocation:
julia> A = res.alloc
Allocation with 2 agents and 3 items:
1 => {3}
2 => {1, 2}
The bundles of each agent is available through the bundle function:
julia> bundle(A, 2)
Set{Int64} with 2 elements:
2
1
Bundles should not be modified directly, as the Allocation also maintains an
inverse mapping, from items to agents. Rather, use the give! and deny!
functions.
Some allocation functions may produce other results as well, such as properties
of the allocation that are naturally computed as part of the allocation process.
For the MNW case, the objective value (the Nash welfare, which is being
maximized) is available as mnw:
julia> res.mnw
15.0
The allocation functions also permit a matrix argument as a shortcut, implicitly
creating an Additive. For example, you can find a maximin share (MMS)
allocation as follows:
julia> alloc_mms([1 1 2 3; 2 1 2 3]).alloc
Allocation with 2 agents and 4 items:
1 => {2, 3}
2 => {1, 4}
Solver configuration
Several allocation functions use mixed-integer linear programming via
JuMP. Depending on the choice of MIP solver, solving even
moderately-sized instances may take a significant amount of time. Choosing a
different solver (from the default HiGHS.Optimizer) may speed things up
considerably. For example, with the appropriate license, one could use use
Gurobi as follows:[^2]
Allocations.conf.MIP_SOLVER = Gurobi.Optimizer
It is also possible to supply the Optimizer (or other optimizer factories,
e.g., constructed using optimizer_with_attributes) as the solver keyword
argument to the relevant allocation functions.
Normally, the MIP solvers will print out quite a lot of information about what
they're doing. If you're not interested in this output, you can generally turn
it off using some solver-specific flag, supplied to
optimizer_with_attributes.[^3] This is also where you'd supply other
parameters, e.g., indicating time limits, acceptable inaccuracies, etc. For
example:[^4]
Allocations.conf.MIP_SOLVER = optimizer_with_attributes(
Gurobi.Optimizer,
"LogToConsole" => 0, # No console output
"TimeLimit" => 60, # Finish within 60 seconds
"MipGap" => 0.05, # Permit 5% suboptimality
)
If you're unable to get rid of the output using solver parameters, a simple solution is to just silence all output while allocating:
julia> redirect_stdout(devnull) do
alloc_mnw(V)
end
If that doesn't do the trick, you could add redirect_stderr as well.
[^1]: The latter is less common, presumably because the two sets then intersect. An alternative is to let $M$ be a set of opaque objects $gj$, for $j=1\dots m$. [^2]: If you're a student or a researcher, Gurobi is available for free under an academic license. [^3]: There is also the `JuMP.setsilent` function, but it requires access to the MIP model. [^4]: See the Gurobi manual for explanations.
Owner
- Name: Magnus Lie Hetland
- Login: mlhetland
- Kind: user
- Repositories: 7
- Profile: https://github.com/mlhetland
Citation (CITATION.cff)
cff-version: "1.2.0"
title: "Allocations.jl"
abstract: "Algorithms for fair item allocation."
message: "If you use this software, please cite it as below."
type: "software"
authors:
- given-names: "Magnus Lie"
family-names: "Hetland"
email: "mlh@ntnu.no"
orcid: "https://orcid.org/0000-0003-4204-2017"
- given-names: "Halvard"
family-names: "Hummel"
orcid: "https://orcid.org/0000-0001-5691-8177"
email: "halvard.hummel@ntnu.no"
repository-code: "https://github.com/mlhetland/Allocations.jl"
version: "0.2.0"
date-released: 2024-05-16
GitHub Events
Total
- Push event: 4
Last Year
- Push event: 4
Issues and Pull Requests
Last synced: 7 months ago
All Time
- Total issues: 1
- Total pull requests: 0
- Average time to close issues: 2 days
- Average time to close pull requests: N/A
- Total issue authors: 1
- Total pull request authors: 0
- Average comments per issue: 1.0
- Average comments per pull request: 0
- Merged pull requests: 0
- Bot issues: 0
- Bot pull requests: 0
Past Year
- Issues: 0
- Pull requests: 0
- Average time to close issues: N/A
- Average time to close pull requests: N/A
- Issue authors: 0
- Pull request authors: 0
- Average comments per issue: 0
- Average comments per pull request: 0
- Merged pull requests: 0
- Bot issues: 0
- Bot pull requests: 0
Top Authors
Issue Authors
- sutne (1)
Pull Request Authors
Top Labels
Issue Labels
Pull Request Labels
Packages
- Total packages: 1
-
Total downloads:
- julia 3 total
- Total dependent packages: 0
- Total dependent repositories: 0
- Total versions: 2
juliahub.com: Allocations
Algorithms for fair item allocation.
- Documentation: https://docs.juliahub.com/General/Allocations/stable/
- License: MIT
-
Latest release: 0.2.0
published almost 2 years ago
Rankings
Dependencies
- actions/checkout v2 composite
- julia-actions/cache v1 composite
- julia-actions/julia-buildpkg v1 composite
- julia-actions/julia-runtest v1 composite
- julia-actions/setup-julia v1 composite
- actions/checkout v2 composite
- julia-actions/setup-julia v1 composite