Skip to main content

A Python package for simple and efficient implementation of Evidential Reasoning (ER) methods.

Project description

ERTool

ERTool is a Python package designed for simple and efficient implementation of Evidential Reasoning (ER) methods. It aims to provide an intuitive and flexible approach for integrating ER processes, particularly suitable for data analysis and decision support systems.

Features

  • Easy-to-use implementation of Evidential Reasoning.
  • Efficient in handling complex ER tasks.
  • Flexible interface suitable for various application scenarios.

Installation

You can install ERTool directly from PyPI using pip:

pip install ertool

Using Instruction

dempster_shafer

ertool.er.dempster_shafer(DBF, numOfEvidence, numOfProposition) -> B

dempster_shafer() can implement the original Dempster-Shafer evidence theory.

Input Variables

  • DBF: A two-dimensional numpy array of floats. It stands for "Degrees of Belief" and is one of the main inputs to the algorithm, used to represent the initial belief degrees for each category or proposition.
  • numOfEvidence: An integer. It indicates the number of evidence nodes. In the DBF array, this typically corresponds to the number of rows.
  • numOfProposition: An integer. It indicates the number of categories or propositions. In the DBF array, this typically corresponds to the number of columns.

Output Values

  • B Array: Upon completion of the algorithm, the B array is the final calculation result. It reflects the degrees of belief that have been weighted and normalized.
  • False (Boolean): It returns B Array if the algorithm successfully executes and completes all computations. If any error is encountered during execution (e.g., division by zero), it returns False.

er_algorithm

ertool.er.er_algorithm(W, DBF, numOfEvidence, numOfProposition) -> B

er_algorithm() can implement the Evidential Reasoning (ER) algorithm.

Input Variables

  • W: A one-dimensional numpy array of floats. It represents the weights of each child node. These weights are used in the algorithm to adjust the influence of each child node.
  • DBF: A two-dimensional numpy array of floats. It stands for "Degrees of Belief" and is one of the main inputs to the algorithm, used to represent the initial belief degrees for each category or proposition.
  • numOfEvidence: An integer. It indicates the number of evidence nodes. In the DBF array, this typically corresponds to the number of rows.
  • numOfProposition: An integer. It indicates the number of categories or propositions. In the DBF array, this typically corresponds to the number of columns.

Output Values

  • B Array: Upon completion of the algorithm, the B array is the final calculation result. It reflects the degrees of belief that have been weighted and normalized.
  • False (Boolean): It returns B Array if the algorithm successfully executes and completes all computations. If any error is encountered during execution (e.g., division by zero), it returns False.

Quick Start

Here is a basic usage example of ERTool.

Consider a medical scenario. There are three medical experts (weights 10, 8, and 5). For one patient, the three experts rated the different likelihood of the diagnosis of cold, common pneumonia, COVID-19, and uncertain. As shown in the table.

Experts & Diseases Expert 1 Expert 2 Expert 3
Cold 90% 0 0
Common Pneumonia 0 90% 0
COVID-19 0 0 90%
Uncertain 10% 10% 10%

In this case, the numOfEvidence is 3 (the number of experts) and the numOfProposition is 4 (cold, common pneumonia, COVID-19, and uncertain).

The W array is the weights array of every expert and the ERTool package can normalize them automatically.

We can write the code using the ERTool package:

import ertool
import numpy as np

W = np.array([10,8,5])
DBF = np.array([[0.9, 0, 0, 0.1], 
                [0, 0.9, 0, 0.1], 
                [0, 0, 0.9, 0.1]])

# List or numpy array are both OK.
# W = [10,8,5]
# DBF = [[0.9, 0, 0, 0.1], 
#        [0, 0.9, 0, 0.1], 
#        [0, 0, 0.9, 0.1]]

numOfEvidence = 3
numOfProposition = 4
B = ertool.er.er_algorithm(W, DBF, numOfEvidence, numOfProposition)
print("B:", B)

With the code, we can calculate the probability that the patient will be diagnosed with each disease using evidential reasoning.

B: [0.43591353 0.30223338 0.15741322 0.10443986]

According to the result, we can know that combining the opinions of the three experts, the probability of the patient being diagnosed with cold, common pneumonia, COVID-19 and uncertain are 0.43591353, 0.30223338, 0.15741322 and 0.10443986.

Contributing

Contributions to ERTool are welcome. Please contact us for how to contribute to the project.

Contact

This project is supported by the National Institute of Health Data Science, Peking University. For any questions or suggestions, please contact us at tyshipku@gmail.com.

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

ERTool-0.1.8.tar.gz (4.5 kB view details)

Uploaded Source

Built Distribution

ERTool-0.1.8-py3-none-any.whl (5.5 kB view details)

Uploaded Python 3

File details

Details for the file ERTool-0.1.8.tar.gz.

File metadata

  • Download URL: ERTool-0.1.8.tar.gz
  • Upload date:
  • Size: 4.5 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/4.0.2 CPython/3.9.6

File hashes

Hashes for ERTool-0.1.8.tar.gz
Algorithm Hash digest
SHA256 073a3ce7622b65b389ce01227252d46f2194b3c0c822bda455303df635c6a8da
MD5 8350d0ced4ef764c400177a196d60615
BLAKE2b-256 3238ecdedcd82815180498e4fd7eff3a42beebab7d10ca0a40687a3ed65486c8

See more details on using hashes here.

File details

Details for the file ERTool-0.1.8-py3-none-any.whl.

File metadata

  • Download URL: ERTool-0.1.8-py3-none-any.whl
  • Upload date:
  • Size: 5.5 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/4.0.2 CPython/3.9.6

File hashes

Hashes for ERTool-0.1.8-py3-none-any.whl
Algorithm Hash digest
SHA256 8070e6ce0291d703d842437ee59815e08b6f1d166f4bc0bff0570d467c5781e6
MD5 d9f35075f2488517b2f40b64864f2e59
BLAKE2b-256 cd228a8cf34b020ab528f64f51f111cd5b451cc1e183ae2fedf4c5dabe2da88e

See more details on using hashes here.

Supported by

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