معرفی شرکت ها


dycelib-0.4.0


Card image cap
تبلیغات ما

مشتریان به طور فزاینده ای آنلاین هستند. تبلیغات می تواند به آنها کمک کند تا کسب و کار شما را پیدا کنند.

مشاهده بیشتر
Card image cap
تبلیغات ما

مشتریان به طور فزاینده ای آنلاین هستند. تبلیغات می تواند به آنها کمک کند تا کسب و کار شما را پیدا کنند.

مشاهده بیشتر
Card image cap
تبلیغات ما

مشتریان به طور فزاینده ای آنلاین هستند. تبلیغات می تواند به آنها کمک کند تا کسب و کار شما را پیدا کنند.

مشاهده بیشتر
Card image cap
تبلیغات ما

مشتریان به طور فزاینده ای آنلاین هستند. تبلیغات می تواند به آنها کمک کند تا کسب و کار شما را پیدا کنند.

مشاهده بیشتر
Card image cap
تبلیغات ما

مشتریان به طور فزاینده ای آنلاین هستند. تبلیغات می تواند به آنها کمک کند تا کسب و کار شما را پیدا کنند.

مشاهده بیشتر

توضیحات

Simple Python tools for exploring dice outcomes and other finite discrete probabilities
ویژگی مقدار
سیستم عامل -
نام فایل dycelib-0.4.0
نام dycelib
نسخه کتابخانه 0.4.0
نگهدارنده []
ایمیل نگهدارنده []
نویسنده Matt Bogosian
ایمیل نویسنده matt@bogosian.net
آدرس صفحه اصلی https://posita.github.io/dyce/0.4/
آدرس اینترنتی https://pypi.org/project/dycelib/
مجوز MIT License
<!-- -*- encoding: utf-8 -*- !!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! !!!!!!!!!!!!!!! IMPORTANT: READ THIS BEFORE EDITING! !!!!!!!!!!!!!!! !!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! Please keep each sentence on its own unwrapped line. It looks like crap in a text editor, but it has no effect on rendering, and it allows much more useful diffs. Thank you! WARNING: THIS DOCUMENT MUST BE SELF-CONTAINED. ALL LINKS MUST BE ABSOLUTE. This file is used on GitHub and PyPi (via setup.py). There is no guarantee that other docs/resources will be available where this content is displayed. --> *Copyright and other protections apply. Please see the accompanying ``LICENSE`` file for rights and restrictions governing use of this software. All rights not expressly waived or licensed are reserved. If that file is missing or appears to be modified from its original, then please contact the author before viewing or using this software in any capacity.* [![Version](https://img.shields.io/pypi/v/dycelib/0.4.0.svg)](https://pypi.org/project/dycelib/0.4.0/) [![Development Stage](https://img.shields.io/pypi/status/dycelib/0.4.0.svg)](https://pypi.org/project/dycelib/0.4.0/) [![License](https://img.shields.io/pypi/l/dycelib/0.4.0.svg)](http://opensource.org/licenses/MIT) [![Supported Python Versions](https://img.shields.io/pypi/pyversions/dycelib/0.4.0.svg)](https://pypi.org/project/dycelib/0.4.0/) [![Supported Python Implementations](https://img.shields.io/pypi/implementation/dycelib/0.4.0.svg)](https://pypi.org/project/dycelib/0.4.0/) [![Bear-ified™](https://raw.githubusercontent.com/beartype/beartype-assets/main/badge/bear-ified.svg)](https://beartype.rtfd.io/) Now you’re playing with… <img style="float: right; padding: 0 1.0em 0 1.0em;" src="https://raw.githubusercontent.com/posita/dyce/v0.4.0/docs/dyce.svg" alt="dyce logo"> # ``dyce`` – simple Python tools for exploring dice outcomes and other finite discrete probabilities **💥 _Now 100% [Bear-ified™](https://beartype.rtfd.io/)!_ 👌🏾🐻** ([Details](#requirements) below.) ``dyce`` is a pure-Python library for modeling arbitrarily complex dice mechanics. It strives for ***compact expression*** and ***efficient computation***, especially for the most common cases. Its primary applications: 1. Computing finite discrete probability distributions for: * Game designers who want to understand or experiment with various dice mechanics and interactions; * Players (including game masters) who may be curious about in-game probabilities; and * Tool authors who serve those game designers or players. 1. Generating transparent, weighted random rolls for: * Software developers who want to enable flexible dice mechanic resolution in their gaming environments such as chat servers or virtual tabletops (VTTs). Beyond those audiences, it may be useful to anyone interested in exploring finite discrete probabilities but not in developing all the low-level math bits from scratch. ``dyce`` is designed to be immediately and broadly useful with minimal additional investment beyond basic knowledge of Python. While not as compact as a dedicated grammar, ``dyce``’s Python-based primitives are quite sufficient, and often more expressive. Those familiar with various [game notations](https://en.wikipedia.org/wiki/Dice_notation) should be able to adapt quickly. If you’re looking at something on which to build your own grammar or interface, ``dyce`` can serve you well. ``dyce`` should be able to replicate or replace most other dice probability modeling tools. It strives to be [fully documented](https://posita.github.io/dyce/0.4/) and relies heavily on examples to develop understanding. ``dyce`` is licensed under the [MIT License](https://opensource.org/licenses/MIT). See the accompanying ``LICENSE`` file for details. Non-experimental features should be considered stable (but an unquenchable thirst to increase performance remains). See the [release notes](https://posita.github.io/dyce/0.4/notes/) for a summary of version-to-version changes. Source code is [available on GitHub](https://github.com/posita/dyce). If you find it lacking in any way, please don’t hesitate to [bring it to my attention](https://posita.github.io/dyce/0.4/contrib/). ## Customers [![``dyce``-powered!](https://raw.githubusercontent.com/posita/dyce/v0.4.0/docs/dyce-powered.svg)](https://posita.github.io/dyce/) * This could be _you_! 👋 Do you have a project that uses ``dyce``? [Let me know](https://posita.github.io/dyce/0.4/contrib/#filing-issues), and I’ll promote it here! And don’t forget to do your part in perpetuating gratuitous badge-ification! ``` markdown <!-- Markdown --> As of version 1.1, HighRollin is [![dyce-powered](https://raw.githubusercontent.com/posita/dyce/master/docs/dyce-powered.svg)][dyce-powered]! [dyce-powered]: https://posita.github.io/dyce/ "dyce-powered!" ``` ``` rst .. reStructuredText - see https://docutils.sourceforge.io/docs/ref/rst/directives.html#image As of version 1.1, HighRollin is |dyce-powered|! .. |dyce-powered| image:: https://raw.githubusercontent.com/posita/dyce/master/docs/dyce-powered.svg :align: top :target: https://posita.github.io/dyce/ :alt: dyce-powered ``` ``` html <!-- HTML --> As of version 1.1, HighRollin is <a href="https://posita.github.io/dyce/"><img src="https://raw.githubusercontent.com/posita/dyce/master/docs/dyce-powered.svg" alt="dyce-powered" style="vertical-align: middle;"></a>! ``` ## A taste ``dyce`` provides several core primitives. [``H`` objects](https://posita.github.io/dyce/0.4/dyce/#dyce.h.H) represent histograms for modeling finite discrete outcomes, like individual dice. [``P`` objects](https://posita.github.io/dyce/0.4/dyce/#dyce.p.P) represent pools (ordered sequences) of histograms. [``R`` objects](https://posita.github.io/dyce/0.4/dyce/#dyce.r.R) (covered [elsewhere](https://posita.github.io/dyce/0.4/rollin/)) represent nodes in arbitrary roller trees useful for translating from proprietary grammars and generating weighted random rolls that “show their work” without the overhead of enumeration. All support a variety of operations. ``` python >>> from dyce import H >>> d6 = H(6) # a standard six-sided die >>> 2@d6 * 3 - 4 # 2d6 × 3 - 4 H({2: 1, 5: 2, 8: 3, 11: 4, 14: 5, 17: 6, 20: 5, 23: 4, 26: 3, 29: 2, 32: 1}) >>> d6.lt(d6) # how often a first six-sided die shows a face less than a second H({False: 21, True: 15}) >>> abs(d6 - d6) # subtract the least of two six-sided dice from the greatest H({0: 6, 1: 10, 2: 8, 3: 6, 4: 4, 5: 2}) ``` ``` python >>> from dyce import P >>> p_2d6 = 2@P(d6) # a pool of two six-sided dice >>> p_2d6.h() # pools can be collapsed into histograms H({2: 1, 3: 2, 4: 3, 5: 4, 6: 5, 7: 6, 8: 5, 9: 4, 10: 3, 11: 2, 12: 1}) >>> p_2d6 == 2@d6 # pools and histograms are comparable True ``` By providing an optional argument to the [``P.h`` method](https://posita.github.io/dyce/0.4/dyce/#dyce.p.P.h), one can “take” individual dice from pools, ordered least to greatest. (The [``H.format`` method](https://posita.github.io/dyce/0.4/dyce/#dyce.h.H.format) provides rudimentary visualization for convenience.) ``` python >>> p_2d6.h(0) # take the lowest die of 2d6 H({1: 11, 2: 9, 3: 7, 4: 5, 5: 3, 6: 1}) >>> print(p_2d6.h(0).format(width=65)) avg | 2.53 std | 1.40 var | 1.97 1 | 30.56% |############### 2 | 25.00% |############ 3 | 19.44% |######### 4 | 13.89% |###### 5 | 8.33% |#### 6 | 2.78% |# ``` ``` python >>> p_2d6.h(-1) # take the highest die of 2d6 H({1: 1, 2: 3, 3: 5, 4: 7, 5: 9, 6: 11}) >>> print(p_2d6.h(-1).format(width=65)) avg | 4.47 std | 1.40 var | 1.97 1 | 2.78% |# 2 | 8.33% |#### 3 | 13.89% |###### 4 | 19.44% |######### 5 | 25.00% |############ 6 | 30.56% |############### ``` [``H`` objects](https://posita.github.io/dyce/0.4/dyce/#dyce.h.H) provide a [``distribution`` method](https://posita.github.io/dyce/0.4/dyce/#dyce.h.H.distribution) and a [``distribution_xy`` method](https://posita.github.io/dyce/0.4/dyce/#dyce.h.H.distribution_xy) to ease integration with plotting packages like [``matplotlib``](https://matplotlib.org/stable/api/index.html). ``` python >>> import matplotlib # doctest: +SKIP >>> outcomes, probabilities = p_2d6.h(0).distribution_xy() >>> matplotlib.pyplot.bar( ... [v - 0.125 for v in outcomes], ... probabilities, ... alpha=0.75, ... width=0.5, ... label="Lowest", ... ) # doctest: +SKIP >>> outcomes, probabilities = p_2d6.h(-1).distribution_xy() >>> matplotlib.pyplot.bar( ... [v + 0.125 for v in outcomes], ... probabilities, ... alpha=0.75, ... width=0.5, ... label="Highest", ... ) # doctest: +SKIP >>> matplotlib.pyplot.legend() # doctest: +SKIP >>> matplotlib.pyplot.title(r"Taking the lowest or highest die of 2d6") # doctest: +SKIP >>> matplotlib.pyplot.show() # doctest: +SKIP ``` <!-- Should match any title of the corresponding plot title --> ![Plot: Taking the lowest or highest die of 2d6](https://raw.githubusercontent.com/posita/dyce/v0.4.0/docs/img/plot_2d6_lo_hi_gh.png) [``H`` objects](https://posita.github.io/dyce/0.4/dyce/#dyce.h.H) and [``P`` objects](https://posita.github.io/dyce/0.4/dyce/#dyce.p.P) can generate random rolls. ``` python >>> d6 = H(6) >>> d6.roll() # doctest: +SKIP 4 ``` ``` python >>> d10 = H(10) - 1 >>> p_6d10 = 6@P(d10) >>> p_6d10.roll() # doctest: +SKIP (0, 1, 2, 3, 5, 7) ``` See the tutorials on [counting](https://posita.github.io/dyce/0.4/countin/) and [rolling](https://posita.github.io/dyce/0.4/rollin/), as well as the [API guide](https://posita.github.io/dyce/0.4/dyce/) for much more thorough treatments, including detailed examples. ## Design philosophy ``dyce`` is fairly low-level by design, prioritizing ergonomics and composability. It explicitly avoids stochastic simulation, but instead determines outcomes through enumeration and discrete computation. That’s a highfalutin way of saying it doesn’t guess. It *knows*, even if knowing is harder or more limiting. Which, if we possess a modicum of humility, it often is. !!! quote “It’s frightening to think that you might not know something, but more frightening to think that, by and large, the world is run by people who have faith that they know exactly what is going on.” —Amos Tversky Because ``dyce`` exposes Python primitives rather than defining a dedicated grammar and interpreter, one can more easily integrate it with other tools.[^1] It can be installed and run anywhere[^2], and modified as desired. On its own, ``dyce`` is completely adequate for casual tinkering. However, it really shines when used in larger contexts such as with [Matplotlib](https://matplotlib.org/) or [Jupyter](https://jupyter.org/) or embedded in a special-purpose application. [^1]: You won’t find any lexers, parsers, or tokenizers in ``dyce``’s core, other than straight-up Python. That being said, you can always “roll” your own (see what we did there?) and lean on ``dyce`` underneath. It doesn’t mind. It actually [kind of *likes* it](https://posita.github.io/dyce/0.4/rollin/). [^2]: Okay, maybe not _literally_ anywhere, but [you’d be surprised](https://jokejet.com/guys-i-need-a-network-specialist-with-some-python-experience-its-urgent/). Void where prohibited. [Certain restrictions](#requirements) apply. [Do not taunt Happy Fun Ball](https://youtu.be/GmqeZl8OI2M). In an intentional departure from [RFC 1925, § 2.2](https://datatracker.ietf.org/doc/html/rfc1925#section-2), ``dyce`` includes some conveniences, such as minor computation optimizations (e.g., the [``H.lowest_terms`` method](https://posita.github.io/dyce/0.4/dyce/#dyce.h.H.lowest_terms), various other shorthands, etc.) and formatting conveniences (e.g., the [``H.distribution``](https://posita.github.io/dyce/0.4/dyce/#dyce.h.H.distribution), [``H.distribution_xy``](https://posita.github.io/dyce/0.4/dyce/#dyce.h.H.distribution_xy), and [``H.format``](https://posita.github.io/dyce/0.4/dyce/#dyce.h.H.format) methods). ## Comparison to alternatives The following is a best-effort[^3] summary of the differences between various available tools in this space. Consider exploring the [applications and translations](https://posita.github.io/dyce/0.4/translations/) for added color. [^3]: I have attempted to ensure the above is reasonably accurate, but please consider [contributing an issue](https://posita.github.io/dyce/0.4/contrib/) if you observe discrepancies. | | ``dyce``<br>*Bogosian et al.* | [``dice_roll.py``](https://gist.github.com/vyznev/8f5e62c91ce4d8ca7841974c87271e2f)<br>*Karonen* | [python-dice](https://pypi.org/project/python-dice/)<br>*Robson et al.* | [AnyDice](https://anydice.com/)<br>*Flick* | [d20](https://pypi.org/project/d20/)<br>*Curse LLC* | [DnDice](https://github.com/LordSembor/DnDice)<br>*“LordSembor”* | [dice](https://pypi.org/project/dice/)<br>*Clements et al.* | [dice-notation](https://pypi.org/project/dice-notation/)<br>*Garrido* | [dyce](https://pypi.org/project/dyce/)<br>*Eyk* | |---|:---:|:---:|:---:|:---:|:---:|:---:|:---:|:---:|:---:| | Latest release | 2021 | N/A | 2021 | Unknown | 2021 | 2016 | 2021 | 2021 | 2009 | | Actively maintained and documented | ✅ | ⚠️[^4] | ✅ | ✅ | ✅ | ❌ | ✅ | ❌ | ❌ | | Suitable as a dependency in other projects | ✅ | ⚠️[^5] | ✅ | ❌ | ✅ | ⚠️[^5] | ✅ | ❌ | ❌ | | Discrete outcome enumeration | ✅ | ✅ | ✅ | ✅ | ❌ | ✅ | ❌ | ❌ | ❌ | | Arbitrary expressions | ✅ | ⚠️[^6] | ✅ | ✅ | ✅ | ⚠️[^7] | ❌ | ❌ | ❌ | | Arbitrary dice definitions | ✅ | ✅ | ✅ | ✅ | ❌ | ❌ | ❌ | ❌ | ❌ | | Integrates with other tools | ✅ | ✅ | ⚠️[^8] | ❌ | ⚠️[^8] | ✅ | ⚠️[^8] | ⚠️[^8] | ⚠️[^8] | | Open source (can inspect) | ✅ | ✅ | ✅ | ❌ | ✅ | ✅ | ✅ | ✅ | ✅ | | Permissive licensing (can use and extend) | ✅ | ✅ | ✅ | N/A | ✅ | ✅ | ✅ | ✅ | ✅ | <!-- 🔺 dycelib 🔺 python-dice 🔺 d20 🔺 dice 🔺 dyce 🔺 dyce_roll.py 🔺 AnyDice 🔺 DnDice 🔺 dice-notation --> [^4]: Actively maintained, but sparsely documented. The author has [expressed a desire](https://rpg.stackexchange.com/a/166663/71245) to release a more polished version. [^5]: Source can be downloaded and incorporated directly, but there is no packaging, versioning, or dependency tracking. [^6]: Callers must perform their own arithmetic and characterize results in terms of a lightweight die primitive, which may be less accessible to the novice. That being said, the library is remarkably powerful, given its size. [^7]: Limited arithmetic operations are available. The library also provides game-specific functions. [^8]: Results only. Input is limited to specialized grammar. ## License ``dyce`` is licensed under the [MIT License](https://opensource.org/licenses/MIT). See the included [``LICENSE``](https://posita.github.io/dyce/0.4/license/) file for details. Source code is [available on GitHub](https://github.com/posita/dyce). ## Installation Installation can be performed via [PyPI](https://pypi.python.org/pypi/dyce/). ```sh % pip install dycelib ... ``` Alternately, you can download [the source](https://github.com/posita/dyce) and run ``setup.py``. ```sh % git clone https://github.com/posita/dyce.git ... % cd dyce % python setup.py install ... ``` ### Requirements ``dyce`` requires a relatively modern version of Python: * [CPython](https://www.python.org/) (3.7+) * [PyPy](http://pypy.org/) (CPython 3.7+ compatible) It has the following runtime dependencies: * [``typing-extensions``](https://pypi.org/project/typing-extensions/) (with Python <3.9) ``dyce`` will opportunistically use the following, if available at runtime: * [``beartype``](https://pypi.org/project/beartype/) for yummy runtime type-checking goodness (0.8+) [![Bear-ified™](https://raw.githubusercontent.com/beartype/beartype-assets/main/badge/bear-ified.svg)](https://beartype.rtfd.io/) * [``graphviz``](https://pypi.org/project/graphviz/) for visualizing [rollers and rolls](https://posita.github.io/dyce/0.4/rollin/) * [``matplotlib``](https://matplotlib.org/) for visualizing [histograms and pools](https://posita.github.io/dyce/0.4/countin/) If you install ``beartype`` for type checking your own code, but don’t want ``dyce`` to use it (e.g., for performance reasons), you can set the ``DYCE_BEARTYPE`` environment variable to a falsy[^9] value before ``dyce`` is imported. [^9]: I.E., one of: ``0``, ``off``, ``f``, ``false``, and ``no``. See the [hacking quick-start](https://posita.github.io/dyce/0.4/contrib/#hacking-quick-start) for additional development and testing dependencies.


نیازمندی

مقدار نام
- typing-extensions
- beartype
- mike
!=1.2 mkdocs
- mkdocs-exclude
- mkdocs-material
- mkdocstrings
- mypy
- numpy
- pre-commit
- pytest-gitignore
- sympy
- tox
- twine


نحوه نصب


نصب پکیج whl dycelib-0.4.0:

    pip install dycelib-0.4.0.whl


نصب پکیج tar.gz dycelib-0.4.0:

    pip install dycelib-0.4.0.tar.gz