Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/explosion/healthsea
Healthsea is a spaCy pipeline for analyzing user reviews of supplementary products for their effects on health.
https://github.com/explosion/healthsea
healthcare machine-learning named-entity-recognition natural-language-processing pipeline spacy text-classification
Last synced: 3 months ago
JSON representation
Healthsea is a spaCy pipeline for analyzing user reviews of supplementary products for their effects on health.
- Host: GitHub
- URL: https://github.com/explosion/healthsea
- Owner: explosion
- License: mit
- Created: 2021-12-08T12:25:37.000Z (about 3 years ago)
- Default Branch: main
- Last Pushed: 2021-12-08T17:18:23.000Z (about 3 years ago)
- Last Synced: 2024-09-30T05:40:51.340Z (3 months ago)
- Topics: healthcare, machine-learning, named-entity-recognition, natural-language-processing, pipeline, spacy, text-classification
- Language: Python
- Homepage:
- Size: 57 MB
- Stars: 87
- Watchers: 9
- Forks: 16
- Open Issues: 1
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
README
# Welcome to Healthsea ✨
## Create better access to health with spaCy.
Healthsea is a pipeline for analyzing user reviews to supplement products by extracting their effects on health.> Learn more about Healthsea in our [blog post](https://explosion.ai/blog/healthsea)!
![](img/healthsea_anim.gif)
## 💉 Creating better access to health
Healthsea aims to analyze user-written reviews of supplements in relation to their effects on health. Based on this analysis, we try to provide product recommendations.
For many people, supplements are an addition to maintaining health and achieving personal goals. Due to their rising popularity, consumers have increasing access to a variety of products.However, it's likely that most of the products on the market are redundant or produced in a "quantity over quality" fashion to maximize profit. The resulting white noise of products makes it hard to find the right supplements.
**Healthsea automizes the analysis and provides information in a more digestible way.** ✨
---
## 🟢 Requirements
To run this project you need:
```
spacy>=3.2.0
benepar>=0.2.0
torch>=1.6.0
spacy-transformers>=1.1.2
```
You can install them in the project folder via `spacy project run install`## 📖 Documentation
| Documentation | |
| -------------------------- | -------------------------------------------------------------- |
| 🧭 **Usage** | How to use the pipeline |
| ⚙️ **Pipeline** | Learn more about the architecture of the pipeline |
| 🪐 **spaCy project** | Introduction to the spaCy project |
| ✨ **Demos** | Introduction to the Healthsea demos |## 🧭 Usage
The pipeline processes reviews to supplements and returns health effects for every found health aspect.
You can either train the pipeline yourself with the provided datasets in the spaCy project or directly download the trained Healthsea pipeline from Huggingface via
`pip install https://huggingface.co/explosion/en_healthsea/resolve/main/en_healthsea-any-py3-none-any.whl````
import spacynlp = spacy.load("en_healthsea")
doc = nlp("This is great for joint pain.")# Clause Segmentation & Blinding
print(doc._.clauses)> {"split_indices": [0, 7],
> "has_ent": true,
> "ent_indices": [4, 6],
> "blinder": "_CONDITION_",
> "ent_name": "joint pain",
> "cats": {
> "POSITIVE": 0.9824668169021606,
> "NEUTRAL": 0.017364952713251114,
> "NEGATIVE": 0.00002889777533710003,
> "ANAMNESIS": 0.0001394189748680219
> },
> "prediction_text": ["This", "is", "great", "for", "_CONDITION_", "!"]}# Aggregated results
print(doc._.health_effects)> {"joint_pain": {
> "effects": ["POSITIVE"],
> "effect": "POSITIVE",
> "label": "CONDITION",
> "text": "joint pain"
> }}```
---
## ⚙️ Pipeline
The pipeline consists of the following components:
```
pipeline = [sentencizer, tok2vec, ner, benepar, segmentation, clausecat, aggregation]
```It uses Named Entity Recognition to detect two types of entities ```Condition``` and ```Benefit```.
```Condition``` entities are defined as health aspects that are improved by decreasing them. They include diseases, symptoms and general health problems (e.g. pain in back). ```Benefit``` entities on the other hand, are desired states of health (muscle recovery, glowing skin) that improve by increasing them.
![](img/ner_guide.PNG)
The pipeline uses a modified model that performs Clause Segmentation based on the [benepar parser](https://github.com/nikitakit/self-attentive-parser), Entity Blinding and Text Classification. It predicts four exclusive effects: `Positive, Negative, Neutral, and Anamnesis`.
![](img/clausecat_guide.PNG)
---
## 🪐 spaCy project
The ```project``` folder contains a [spaCy project](https://spacy.io/usage/projects) with all the training data and workflows.Use ```spacy project run``` inside the project folder to get an overview of all commands and assets. For more detailed documentation, visit the [project folders readme](https://github.com/thomashacker/healthsea/tree/main/project).
Use ```spacy project run install``` to install dependencies needed for the pipeline.
## ✨ Demo
### Healthsea Demo
A `demo` for exploring the results of Healthsea on real data can be found at [Hugging Face Spaces](https://huggingface.co/spaces/spacy/healthsea-demo).### Healthsea Pipeline
A `demo` for exploring the Healthsea pipeline with its individual processing steps can be found at [Hugging Face Spaces](https://huggingface.co/spaces/spacy/healthsea-pipeline).