BayesNet/sample/lib/mdlp
2024-03-08 01:09:39 +01:00
..
CMakeLists.txt Refactor sample to be out of main CMakeLists 2024-03-08 01:09:39 +01:00
CPPFImdlp.cpp Refactor sample to be out of main CMakeLists 2024-03-08 01:09:39 +01:00
CPPFImdlp.h Refactor sample to be out of main CMakeLists 2024-03-08 01:09:39 +01:00
LICENSE Refactor sample to be out of main CMakeLists 2024-03-08 01:09:39 +01:00
Metrics.cpp Refactor sample to be out of main CMakeLists 2024-03-08 01:09:39 +01:00
Metrics.h Refactor sample to be out of main CMakeLists 2024-03-08 01:09:39 +01:00
README.md Refactor sample to be out of main CMakeLists 2024-03-08 01:09:39 +01:00
typesFImdlp.h Refactor sample to be out of main CMakeLists 2024-03-08 01:09:39 +01:00

Build Quality Gate Status Reliability Rating

mdlp

Discretization algorithm based on the paper by Fayyad & Irani Multi-Interval Discretization of Continuous-Valued Attributes for Classification Learning

The implementation tries to mitigate the problem of different label values with the same value of the variable:

  • Sorts the values of the variable using the label values as a tie-breaker
  • Once found a valid candidate for the split, it checks if the previous value is the same as actual one, and tries to get previous one, or next if the former is not possible.

Other features:

  • Intervals with the same value of the variable are not taken into account for cutpoints.
  • Intervals have to have more than two examples to be evaluated.

The algorithm returns the cut points for the variable.

Sample

To run the sample, just execute the following commands:

cd sample
cmake -B build
cd build
make
./sample -f iris -m 2
./sample -h

Test

To run the tests and see coverage (llvm & gcovr have to be installed), execute the following commands:

cd tests
./test