Skip to main content

Z-number data type for fuzzy arithmetic and multi-criteria decision making (TOPSIS, PROMETHEE)

Project description

Znum logo

Znum

A Python library for Z-number arithmetic and multi-criteria decision making (MCDM).

A Z-number is a fuzzy number with two components:

  • A: The main fuzzy set values (restriction on values)
  • B: The confidence/belief values (reliability of A)

Znum supports full mathematical operations (addition, subtraction, multiplication, division, power), comparison operators, and includes implementations of TOPSIS and PROMETHEE optimization methods.

Installation

pip install znum

Quick Start

from znum import Znum

# Create Z-numbers
z1 = Znum([1, 2, 3, 4], [0.1, 0.2, 0.3, 0.4])
z2 = Znum([2, 4, 8, 10], [0.5, 0.6, 0.7, 0.8])

# Arithmetic operations
z3 = z1 + z2
z4 = z1 * z2
z5 = z1 - z2
z6 = z1 / z2

# Comparison
print(z1 > z2)  # False
print(z1 < z2)  # True

# Power
z7 = z1 ** 2

MCDM Methods

TOPSIS

from znum import Znum, Topsis, MCDMUtils

# Create weights, alternatives, and criteria types
weights = [Znum([0.2, 0.3, 0.4, 0.5], [0.1, 0.2, 0.3, 0.4])]
alternatives = [[Znum([7, 8, 9, 10], [0.6, 0.7, 0.8, 0.9])]]
criteria_types = [MCDMUtils.CriteriaType.BENEFIT]

table = [weights, *alternatives, criteria_types]
topsis = Topsis(table)
result = topsis.solve()

# Access results
best_idx = topsis.index_of_best_alternative
worst_idx = topsis.index_of_worst_alternative
ranking = topsis.ordered_indices

PROMETHEE

from znum import Znum, Promethee, MCDMUtils

table = [weights, *alternatives, criteria_types]
promethee = Promethee(table)
sorted_alternatives = promethee.solve()

# Access results
best_idx = promethee.index_of_best_alternative
worst_idx = promethee.index_of_worst_alternative
ranking = promethee.ordered_indices

Development

# Install dependencies
pip install -e ".[dev]"

# Run tests
pytest

License

MIT

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

znum-4.0.0.tar.gz (58.2 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

znum-4.0.0-py3-none-any.whl (22.9 kB view details)

Uploaded Python 3

File details

Details for the file znum-4.0.0.tar.gz.

File metadata

  • Download URL: znum-4.0.0.tar.gz
  • Upload date:
  • Size: 58.2 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.7

File hashes

Hashes for znum-4.0.0.tar.gz
Algorithm Hash digest
SHA256 050214ef9f57d110a1b4db0b1c1e3ccf0e979aab15a7d4340754124b796c35a1
MD5 684a466f1698d0d3228e4bea1174e8e5
BLAKE2b-256 445d6992e8bff23cc983b6553131d05be12e16b6490e313174d4696a758279a0

See more details on using hashes here.

Provenance

The following attestation bundles were made for znum-4.0.0.tar.gz:

Publisher: publish.yml on MahammadNuriyev62/Znum

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

File details

Details for the file znum-4.0.0-py3-none-any.whl.

File metadata

  • Download URL: znum-4.0.0-py3-none-any.whl
  • Upload date:
  • Size: 22.9 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.7

File hashes

Hashes for znum-4.0.0-py3-none-any.whl
Algorithm Hash digest
SHA256 40e2f8f4bc2cd650e9ab154d565400661bf8de42f34e6540034a0396cee2fbae
MD5 8b2f66e379546f6978160905d11103c1
BLAKE2b-256 e5b720eab8e4a6bcc000b02c0d8af95ab1f5ac466f0937329e7b26bfe842490b

See more details on using hashes here.

Provenance

The following attestation bundles were made for znum-4.0.0-py3-none-any.whl:

Publisher: publish.yml on MahammadNuriyev62/Znum

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page