Skip to main content

FM Fact Label backend to characterize feature models.

Project description

Table of Contents

FM Fact Label: A Configurable and Interactive Visualization of Feature Model Characterizations

A tool to generate visualizations of feature model characterizations as a fact label similar to the nutritions fact label.

Available online

Artifact description

FM Fact Label is an online web-based application that builds an FM characterization and generates its visualization as a fact label.

It offers a web service providing an online form to upload the FM and its metadata. Currently, UVL and FeatureIDE formats are supported. At this date, the FM characterization provides up to 46 measures, including metrics and analysis results, and it is open to extension with further metrics from the SPL literature. The fact label visualization is automatically generated using D3. D3 relies on web standards (HTML, CSS, JavaScript, SVG, and JSON) to combine visualization components and a data-driven approach that allows binding arbitrary data to a Document Object Model (DOM), and then applying data-driven transformations to the DOM. The tool benefits from D3 to provide an interactive and configurable visualization of the FM characterization.

How to use it

The tool is currently deployed and available online in the following link:

https://fmfactlabel.adabyron.uma.es/

The main use case of the tool is uploading an FM and automatically generates a visualization of its characterization which can be customized and exported. The use case can be described with the following steps:

  • Upload an FM and provide metadata.
  • Build the FM characterization and generate the FM fact label.
  • Interact with the FM fact label.
  • Customize the FM fact label.
  • Export the FM fact label and the FM characterization.

Deployment of the web application locally

Requirements

Download and install

  1. Install Python 3.9+

  2. Clone this repository and enter into the main directory:

    git clone https://github.com/jmhorcas/fm_characterization

    cd fm_characterization

  3. Create a virtual environment:

    python -m venv env

  4. Activate the environment:

    In Linux: source env/bin/activate

    In Windows: .\env\Scripts\Activate

  5. Install the dependencies:

    pip install -r requirements.txt

Execution

To run the server locally execute the following command:

python run.py

Access to the web service in the localhost:

http://127.0.0.1:5000 or http://10.141.0.170:5000

Video

https://user-images.githubusercontent.com/1789503/172726157-11ebe212-41f6-47a1-9ab7-ee378ed1aab7.mp4

Architecture and repository's structure and contents

Here is a description of the architecture of the tool and the folders' structure and contents of this repository for those interesting in contributing to the project.

Software architecture

Software architecture

The tool offers a web service to upload the feature model and its metadata via an online form (Web Service component). It supports feature models in UVL and FeatureIDE formats. The FM Characterization module in the server-side gathers and manages all the feature model information. We distinguish three kinds of information: metadata (FM Metadata), structural metrics (FM Metrics), and analysis results (FM Analysis), treating all of them as an FM property. Each FM Property includes a name, a description, and a parent property for hierarchical organization in the fact label. Properties are associated with an FM Property Measure that provides the specific values of the property. For instance, the list of abstract features, their size, and ratio for the ABSTRACT FEATURES property. Analysis tasks are delegated to external tools, with the current implementation relying on flama (dark component).

Repository's structure and contents

  • run.py: It is the entry point of the application that consists on a Flask server to expose the tool's functionality.
  • fm_characterization: Contains the code related to the server-side of the architecture in charge of gathering all the information of the feature model that is needed to build the fact label. Concretely, it contains the FM Characterization, FM Metadata, FM Metrics, FM Analysis, FM property, and FM Property Measure modules, among other utils. The dependency with the flama library is on the FM Analysis module.
  • web: Contains the code related with the client-side of the architecture in charge of building the visualization of the fact label from the JSON information provided by the server-side. Concretely, it contains the HTML, CSS, and JavaScript files, where the most important is the fm_fact_label.js script which contains the main code in D3.js to build the visualization of the fact label. Also, the fm_models contains the feature models examples availables in the tool.
  • resources: Contains the images and videos used in this README.md file.

Generate Pypi package

  1. Install needed tools: pip install --upgrade build twine
  2. Build the package: python -m build
  3. Upload the package to TestPypI: python -m twine upload --repository testpypi dist/*
  4. Upload the package to PypI: python -m twine upload dist/*

References and third-party software

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

fmfactlabel-1.8.2.tar.gz (20.8 kB view details)

Uploaded Source

Built Distribution

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

fmfactlabel-1.8.2-py3-none-any.whl (19.9 kB view details)

Uploaded Python 3

File details

Details for the file fmfactlabel-1.8.2.tar.gz.

File metadata

  • Download URL: fmfactlabel-1.8.2.tar.gz
  • Upload date:
  • Size: 20.8 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.14.3

File hashes

Hashes for fmfactlabel-1.8.2.tar.gz
Algorithm Hash digest
SHA256 85ac5487a3be310b3b4e4c663ea5fe359ac17f8aa5b8c2c95bcf1c502bd1f6c6
MD5 c16fe6fb3250e852fd0f13ffd1cd0cf9
BLAKE2b-256 01c1968f4d6a364c97176c297c2d1f23820c4e88a6bce8b128ae1720860604ff

See more details on using hashes here.

File details

Details for the file fmfactlabel-1.8.2-py3-none-any.whl.

File metadata

  • Download URL: fmfactlabel-1.8.2-py3-none-any.whl
  • Upload date:
  • Size: 19.9 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.14.3

File hashes

Hashes for fmfactlabel-1.8.2-py3-none-any.whl
Algorithm Hash digest
SHA256 bb66674f5fe4cd809b9b337a74d1ccfa64a573d1d6d7b9122c37921ec414ade6
MD5 1a80ed1b8bc3f3fa83c0993f7c117c62
BLAKE2b-256 bd34d8c356296f89bd5eb4c104a82ac26417135b5096c83d977fe0d35798f20a

See more details on using hashes here.

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