Name | constructor-lib JSON |
Version |
0.0.1
JSON |
| download |
home_page | https://pypi.org/project/constructor-lib/ |
Summary | Constructor is a Python library that enables the simulation and exploration of physical transformations within the framework of Constructor Theory, focusing on what tasks are possible or impossible under the laws of physics. |
upload_time | 2024-09-05 01:29:02 |
maintainer | None |
docs_url | None |
author | Chris Mangum |
requires_python | >=3.10 |
license | None |
keywords |
|
VCS |
|
bugtrack_url |
|
requirements |
No requirements were recorded.
|
Travis-CI |
No Travis.
|
coveralls test coverage |
No coveralls.
|
# Constructor
`Constructor` is a Python library designed to facilitate the simulation and exploration of [Constructor Theory](https://www.constructortheory.org/), a novel framework that reimagines the fundamental principles of physics. Rather than focusing on the dynamics of how systems evolve over time, Constructor Theory emphasizes what transformations (or "tasks") are possible or impossible within the physical laws of the universe.
With `Constructor`, researchers and enthusiasts can model and simulate abstract "constructors"—entities capable of performing tasks on physical systems without undergoing any net change themselves. The library allows users to define tasks, substrates, and conditions under which transformations can occur, enabling the exploration of fundamental questions about the nature of possibility and impossibility in physics.
Based on the theory developed by [David Deutsch](https://www.daviddeutsch.org.uk/) and [Chiara Marletto](https://www.chiaramarletto.com/)
## **Key Features**
- **Constructor Modeling**: Define constructors, abstract machines that can perform specific tasks without being degraded by the process. Constructors are central to the framework and can be customized to fit a variety of scenarios.
- **Task Definition**: Represent physical transformations as tasks that can be performed on substrates. Tasks define both the initial and final states of a system, as well as the conditions required for their execution.
- **Substrate Representation**: Model substrates as physical systems with defined states and properties. Substrates are the objects upon which tasks operate, and their states can be modified by constructors.
- **Condition Constraints**: Implement conditions that must be met for tasks to be possible. These can involve the state or properties of substrates, environmental factors, or probabilistic elements.
- **Simulation Engine**: Run simulations that apply constructors to substrates according to the tasks defined. The engine determines which tasks are possible or impossible under the given conditions, allowing users to explore the boundaries of physical transformations.
- **Extensibility**: Easily extend the library with more complex substrates, probabilistic tasks, quantum operations, or environmental conditions. The modular design allows for flexibility and growth as your research progresses.
- **Visualization and Analysis**: (Planned feature) Tools for visualizing the results of simulations, including state transitions and the network of possible transformations.
## **Use Cases**
- **Theoretical Physics Research**: Explore fundamental questions about what can or cannot be done within the laws of physics, testing hypotheses related to information theory, thermodynamics, and quantum mechanics.
- **Educational Tools**: Provide students with a hands-on way to understand the principles of Constructor Theory, allowing them to simulate and visualize abstract concepts.
- **Interdisciplinary Applications**: Apply the principles of Constructor Theory to other fields, such as biology (evolution of life), computer science (computation theory), and engineering (design of resilient systems).
## **Installation**
```bash
pip install constructor-lib
```
## **Usage**
Take a look at a simple example or one of the sample implementations:
- [Information](./examples/information.ipynb)
- [Thermodynamics](./examples/thermodynamics.ipynb)
- [Quantum](./examples/quantum.ipynb)
- [Cellular Automata](./examples/cellular_automata.ipynb)
Raw data
{
"_id": null,
"home_page": "https://pypi.org/project/constructor-lib/",
"name": "constructor-lib",
"maintainer": null,
"docs_url": null,
"requires_python": ">=3.10",
"maintainer_email": null,
"keywords": null,
"author": "Chris Mangum",
"author_email": "csmangum@gmail.com",
"download_url": "https://files.pythonhosted.org/packages/cc/cb/ea13166d0c679c5ce9e2b40e4d4075a2f328f267a3bada31a20cb7a16cd0/constructor_lib-0.0.1.tar.gz",
"platform": null,
"description": "# Constructor\n\n`Constructor` is a Python library designed to facilitate the simulation and exploration of [Constructor Theory](https://www.constructortheory.org/), a novel framework that reimagines the fundamental principles of physics. Rather than focusing on the dynamics of how systems evolve over time, Constructor Theory emphasizes what transformations (or \"tasks\") are possible or impossible within the physical laws of the universe.\n\nWith `Constructor`, researchers and enthusiasts can model and simulate abstract \"constructors\"\u2014entities capable of performing tasks on physical systems without undergoing any net change themselves. The library allows users to define tasks, substrates, and conditions under which transformations can occur, enabling the exploration of fundamental questions about the nature of possibility and impossibility in physics.\n\nBased on the theory developed by [David Deutsch](https://www.daviddeutsch.org.uk/) and [Chiara Marletto](https://www.chiaramarletto.com/)\n\n## **Key Features**\n\n- **Constructor Modeling**: Define constructors, abstract machines that can perform specific tasks without being degraded by the process. Constructors are central to the framework and can be customized to fit a variety of scenarios.\n\n- **Task Definition**: Represent physical transformations as tasks that can be performed on substrates. Tasks define both the initial and final states of a system, as well as the conditions required for their execution.\n\n- **Substrate Representation**: Model substrates as physical systems with defined states and properties. Substrates are the objects upon which tasks operate, and their states can be modified by constructors.\n\n- **Condition Constraints**: Implement conditions that must be met for tasks to be possible. These can involve the state or properties of substrates, environmental factors, or probabilistic elements.\n\n- **Simulation Engine**: Run simulations that apply constructors to substrates according to the tasks defined. The engine determines which tasks are possible or impossible under the given conditions, allowing users to explore the boundaries of physical transformations.\n\n- **Extensibility**: Easily extend the library with more complex substrates, probabilistic tasks, quantum operations, or environmental conditions. The modular design allows for flexibility and growth as your research progresses.\n\n- **Visualization and Analysis**: (Planned feature) Tools for visualizing the results of simulations, including state transitions and the network of possible transformations.\n\n## **Use Cases**\n\n- **Theoretical Physics Research**: Explore fundamental questions about what can or cannot be done within the laws of physics, testing hypotheses related to information theory, thermodynamics, and quantum mechanics.\n\n- **Educational Tools**: Provide students with a hands-on way to understand the principles of Constructor Theory, allowing them to simulate and visualize abstract concepts.\n\n- **Interdisciplinary Applications**: Apply the principles of Constructor Theory to other fields, such as biology (evolution of life), computer science (computation theory), and engineering (design of resilient systems).\n\n## **Installation**\n\n```bash\npip install constructor-lib\n```\n\n## **Usage**\n\nTake a look at a simple example or one of the sample implementations:\n\n- [Information](./examples/information.ipynb)\n- [Thermodynamics](./examples/thermodynamics.ipynb)\n- [Quantum](./examples/quantum.ipynb)\n- [Cellular Automata](./examples/cellular_automata.ipynb)\n",
"bugtrack_url": null,
"license": null,
"summary": "Constructor is a Python library that enables the simulation and exploration of physical transformations within the framework of Constructor Theory, focusing on what tasks are possible or impossible under the laws of physics.",
"version": "0.0.1",
"project_urls": {
"Homepage": "https://pypi.org/project/constructor-lib/"
},
"split_keywords": [],
"urls": [
{
"comment_text": "",
"digests": {
"blake2b_256": "29f3fbd74e1b69c3af65941ec9f31624f672bba92deb630196e64b17b9ca0755",
"md5": "0338a93b641f44f9d22faf72e2435f93",
"sha256": "b749c31279cb29154e845aae3e8898f1f3ab637ba0da98d30fbcc3fa96dc68ea"
},
"downloads": -1,
"filename": "constructor_lib-0.0.1-py3-none-any.whl",
"has_sig": false,
"md5_digest": "0338a93b641f44f9d22faf72e2435f93",
"packagetype": "bdist_wheel",
"python_version": "py3",
"requires_python": ">=3.10",
"size": 8415,
"upload_time": "2024-09-05T01:29:01",
"upload_time_iso_8601": "2024-09-05T01:29:01.018034Z",
"url": "https://files.pythonhosted.org/packages/29/f3/fbd74e1b69c3af65941ec9f31624f672bba92deb630196e64b17b9ca0755/constructor_lib-0.0.1-py3-none-any.whl",
"yanked": false,
"yanked_reason": null
},
{
"comment_text": "",
"digests": {
"blake2b_256": "cccbea13166d0c679c5ce9e2b40e4d4075a2f328f267a3bada31a20cb7a16cd0",
"md5": "a0c564599d78d083a31a82d42dea99ee",
"sha256": "a9974ff2e04fb4d7949418dd8f9c4ee0b0a0d64ad4edd9b97eb9b9ed5bc5ab89"
},
"downloads": -1,
"filename": "constructor_lib-0.0.1.tar.gz",
"has_sig": false,
"md5_digest": "a0c564599d78d083a31a82d42dea99ee",
"packagetype": "sdist",
"python_version": "source",
"requires_python": ">=3.10",
"size": 6463,
"upload_time": "2024-09-05T01:29:02",
"upload_time_iso_8601": "2024-09-05T01:29:02.410844Z",
"url": "https://files.pythonhosted.org/packages/cc/cb/ea13166d0c679c5ce9e2b40e4d4075a2f328f267a3bada31a20cb7a16cd0/constructor_lib-0.0.1.tar.gz",
"yanked": false,
"yanked_reason": null
}
],
"upload_time": "2024-09-05 01:29:02",
"github": false,
"gitlab": false,
"bitbucket": false,
"codeberg": false,
"lcname": "constructor-lib"
}