This repository contains a Python implementation of the Top Trading Cycle Algorithm, a mechanism for solving the problem of allocating indivisible items or resources among agents with preferences. The algorithm is widely used in the field of matching theory, particularly in the context of school choice and house allocation problems.
The Top Trading Cycle Algorithm is a mechanism designed to find a stable allocation of resources in a way that there are no incentives for agents to trade and improve their allocation. It is a widely used algorithm in various allocation problems, including school assignments, house allocation problems, and more.
To use this Python implementation of the Top Trading Cycle Algorithm, follow these steps:
-
Clone this repository to your local machine:
git clone https://github.com/MohammadYasinKarbasian/Top-Trading-Cycle.git
-
Run the algorithm by executing the main Python script:
python 'top trading cycle.py'
-
Follow the prompts to provide the input data or specify the test file you want to use for allocation.
-
The algorithm will perform the allocation and display the results.
The Top Trading Cycle Algorithm works as follows:
-
Agents express their preferences for items or resources.
-
Starting with an empty allocation, agents are matched in cycles of trades that improve their allocation.
-
A cycle is formed by tracing a path of trades where each agent agrees to trade with the next agent in the cycle.
-
Once a cycle is formed, the resources are reallocated according to the cycle, and the process continues until no more cycles can be formed.
-
The algorithm terminates when a stable allocation is reached, where no agent has an incentive to trade and improve their allocation.
This repository includes four test.txt files containing sample input data for testing the Top Trading Cycle Algorithm. You can use these files to validate the correctness and performance of the implementation. Each test file contains the preferences of agents.
- Test1.txt
- Test2.txt
- Test3.txt
- Test4.txt
Contributions to this project are welcome! If you have suggestions for improvements or bug fixes, please open an issue or create a pull request. For major changes, please discuss them in an issue first.
This project is licensed under the MIT License - see the LICENSE file for details.