Bert Fda Nutrition Ner
模型简介
该模型主要用于从文本数据中识别和分类营养成分,如配料表、营养价值等,适用于营养标签分析。
模型特点
营养标签专用
专门针对营养标签数据设计,能够准确识别和分类营养成分。
多数据源训练
结合FDA公开数据集、Yelp评论和亚马逊食品评论,增强模型对多样化营养信息的理解。
噪声增强
训练数据中引入故意噪声(如拼写错误、句子交换),提高模型在现实场景中的鲁棒性。
模型能力
识别营养成分
分类营养实体
处理拼写错误
分析多样化文本结构
使用案例
食品标签分析
配料表解析
从食品配料表中识别和分类各种成分,如维生素、矿物质、添加剂等。
准确标记出各类营养实体,如'番茄酱'被分类为碳水化合物。
营养信息提取
从食品评论或标签中提取营养信息,如卡路里、蛋白质含量等。
识别并分类营养数据,如'每100克250卡路里'被标记为近似值。
🚀 sgarbi/bert-fda-nutrition-ner模型
这是一个专门为营养标签领域的命名实体识别(NER)设计的BERT模型。其主要目标是从文本数据中检测和分类不同的营养成分,从而为理解营养标签和其他营养材料中的信息提供系统的方法。该模型还可作为从增强数据中训练模型的基准和学习工具。
🚀 快速开始
此模型可直接从Hugging Face平台加载使用,以下是简单的使用示例:
# 假设使用Hugging Face的transformers库
from transformers import AutoTokenizer, AutoModelForTokenClassification
import torch
# 加载模型和分词器
tokenizer = AutoTokenizer.from_pretrained("sgarbi/bert-fda-nutrition-ner")
model = AutoModelForTokenClassification.from_pretrained("sgarbi/bert-fda-nutrition-ner")
# 输入文本
text = "Here are the ingredients to use: Tomato Paste, Sesame Oil, Cheese Cultures, Ground Corn, Vegetable Oil, Brown rice, sea salt, Tomatoes, Milk, Onions, Egg Yolks, Lime Juice Concentrate, Corn Starch, Condensed Milk, Spices, Artificial Flavor, red 5, roasted coffee"
# 分词
inputs = tokenizer(text, return_tensors="pt")
# 模型推理
with torch.no_grad():
outputs = model(**inputs)
# 获取预测结果
predictions = torch.argmax(outputs.logits, dim=2)
# 打印预测结果
print(predictions)
✨ 主要特性
- 精准识别:能够准确识别营养标签文本中的各种营养成分实体。
- 多数据源训练:使用了来自美国食品药品监督管理局(FDA)、Yelp餐厅评论和亚马逊食品评论等多源数据进行训练,增强了模型的泛化能力。
- 数据增强:通过引入噪声等数据增强技术,提高了模型处理真实世界不完美数据的能力。
📦 安装指南
如果你想使用这个模型,可通过以下步骤安装所需依赖:
pip install transformers torch
💻 使用示例
基础用法
# 上述快速开始中的代码示例
from transformers import AutoTokenizer, AutoModelForTokenClassification
import torch
tokenizer = AutoTokenizer.from_pretrained("sgarbi/bert-fda-nutrition-ner")
model = AutoModelForTokenClassification.from_pretrained("sgarbi/bert-fda-nutrition-ner")
text = "Here are the ingredients to use: Tomato Paste, Sesame Oil, Cheese Cultures, Ground Corn, Vegetable Oil, Brown rice, sea salt, Tomatoes, Milk, Onions, Egg Yolks, Lime Juice Concentrate, Corn Starch, Condensed Milk, Spices, Artificial Flavor, red 5, roasted coffee"
inputs = tokenizer(text, return_tensors="pt")
with torch.no_grad():
outputs = model(**inputs)
predictions = torch.argmax(outputs.logits, dim=2)
print(predictions)
高级用法
# 批量处理文本数据
from transformers import AutoTokenizer, AutoModelForTokenClassification
import torch
tokenizer = AutoTokenizer.from_pretrained("sgarbi/bert-fda-nutrition-ner")
model = AutoModelForTokenClassification.from_pretrained("sgarbi/bert-fda-nutrition-ner")
texts = [
"Here are the ingredients to use: Tomato Paste, Sesame Oil, Cheese Cultures, Ground Corn, Vegetable Oil, Brown rice, sea salt, Tomatoes, Milk, Onions, Egg Yolks, Lime Juice Concentrate, Corn Starch, Condensed Milk, Spices, Artificial Flavor, red 5, roasted coffee",
"Beef: 250 calories per 100g Chicken: 165 calories per 100g Salmon: 206 calories per 100g Tofu: 76 calories per 100g Lentils: 116 calories per 100g Carrots: 41 calories per 100g Spinach: 23 calories per 100g Apples: 52 calories per 100g Bananas: 89 calories per 100g Oranges: 47 calories per 100g Rice: 130 calories per 100g cooked Pasta: 131 calories per 100g cooked Bread: 265 calories per 100g Olive oil: 884 calories per 100g Butter: 717 calories per 100g"
]
inputs = tokenizer(texts, return_tensors="pt", padding=True, truncation=True)
with torch.no_grad():
outputs = model(**inputs)
predictions = torch.argmax(outputs.logits, dim=2)
print(predictions)
📚 详细文档
训练数据描述
sgarbi/bert-fda-nutrition-ner
模型的训练数据经过精心策划,主要来源于以下几个方面:
数据来源
数据来源 | 详情 |
---|---|
美国食品药品监督管理局(FDA) | 数据来自FDA的FoodData Central网站(FDA FoodData Central),包含了各种食品的详细营养信息和标签,如成分列表、营养值、份量等。 |
Yelp餐厅评论 | 使用了Hugging Face的 Yelp Review Full dataset,并通过Mistral 7B进行通用标注增强,以丰富模型对餐厅相关营养提及的理解。 |
亚马逊食品评论 | 结合了Hugging Face的 Amazon Food Reviews dataset,同样使用Mistral 7B进行增强,提高了模型从不同食品产品评论中识别和分类营养信息的能力,并与FDA数据相关联。 |
预处理和增强步骤
- 提取:从FDA数据集中提取关键文本数据,包括营养事实和成分列表。
- 归一化:对所有文本进行归一化处理,包括转换为小写和去除冗余格式。
- 实体标注:手动标注重要的营养元素,创建用于训练的标注数据集,包括宏营养素、维生素、矿物质和各种特定的饮食成分。
- 分词和格式化:对数据进行分词和格式化,以满足BERT模型的输入要求。
- 引入噪声:为了提高模型处理真实世界不完美数据的能力,在训练集中引入了故意噪声,包括句子交换和引入拼写错误。
注意事项
- 数据使用:模型仅使用了食品产品标签的公开数据,未使用任何私人或敏感数据。
- 标注问题:标注任务由mistral.ai提供的Mistral 7B-Instruct执行(https://docs.mistral.ai/),标注过程中可能出现幻觉现象,导致分类不准确。
- 功能限制:该工具仅从文本中提取营养实体,不能用于营养或健康建议,营养建议应由专业专家提供。
- 语言偏差:某些类型食品产品标签的语言和措辞可能会给模型带来偏差。
- 模型用途:此模型主要用于探索BERT架构和NER任务。
标签映射
label_map = {
0: 'O',
1: 'I-VITAMINS',
2: 'I-STIMULANTS',
3: 'I-PROXIMATES',
4: 'I-PROTEIN',
5: 'I-PROBIOTICS',
6: 'I-MINERALS',
7: 'I-LIPIDS',
8: 'I-FLAVORING',
9: 'I-ENZYMES',
10: 'I-EMULSIFIERS',
11: 'I-DIETARYFIBER',
12: 'I-COLORANTS',
13: 'I-CARBOHYDRATES',
14: 'I-ANTIOXIDANTS',
15: 'I-ALCOHOLS',
16: 'I-ADDITIVES',
17: 'I-ACIDS',
18: 'B-VITAMINS',
19: 'B-STIMULANTS',
20: 'B-PROXIMATES',
21: 'B-PROTEIN',
22: 'B-PROBIOTICS',
23: 'B-MINERALS',
24: 'B-LIPIDS',
25: 'B-FLAVORING',
26: 'B-ENZYMES',
27: 'B-EMULSIFIERS',
28: 'B-DIETARYFIBER',
29: 'B-COLORANTS',
30: 'B-CARBOHYDRATES',
31: 'B-ANTIOXIDANTS',
32: 'B-ALCOHOLS',
33: 'B-ADDITIVES',
34: 'B-ACIDS'
}
示例输出
INPUT:
'Here are the ingredients to use: Tomato Paste, Sesame Oil, Cheese Cultures, Ground Corn, Vegetable Oil, Brown rice, sea salt, Tomatoes, Milk, Onions, Egg Yolks, Lime Juice Concentrate, Corn Starch, Condensed Milk, Spices, Artificial Flavor, red 5, roasted coffee'
Output:
['CLS', 'O', 'O', 'O', 'O', 'O', 'O', 'O', 'B-CARBOHYDRATES', 'I-CARBOHYDRATES', 'O', 'B-LIPIDS', 'I-LIPIDS', 'O', 'B-PROBIOTICS', 'I-PROBIOTICS', 'O', 'B-CARBOHYDRATES', 'I-CARBOHYDRATES', 'O', 'B-LIPIDS', 'I-LIPIDS', 'O', 'B-CARBOHYDRATES', 'I-CARBOHYDRATES', 'O', 'B-MINERALS', 'I-MINERALS', 'O', 'B-CARBOHYDRATES', 'O', 'B-PROXIMATES', 'O', 'B-CARBOHYDRATES', 'O', 'B-LIPIDS', 'I-LIPIDS', 'I-LIPIDS', 'I-LIPIDS', 'O', 'B-CARBOHYDRATES', 'I-CARBOHYDRATES', 'I-CARBOHYDRATES', 'O', 'B-CARBOHYDRATES', 'I-CARBOHYDRATES', 'I-CARBOHYDRATES', 'O', 'B-PROXIMATES', 'I-PROXIMATES', 'O', 'B-FLAVORING', 'O', 'B-FLAVORING', 'I-FLAVORING', 'O', 'B-COLORANTS', 'I-COLORANTS', 'O', 'B-STIMULANTS', 'I-STIMULANTS', 'O', 'I-STIMULANTS']
代码仓库
https://github.com/ESgarbi/bert-fda-nutrition-ner
📄 许可证
本项目采用MIT许可证。
Indonesian Roberta Base Posp Tagger
MIT
这是一个基于印尼语RoBERTa模型微调的词性标注模型,在indonlu数据集上训练,用于印尼语文本的词性标注任务。
序列标注
Transformers 其他

I
w11wo
2.2M
7
Bert Base NER
MIT
基于BERT微调的命名实体识别模型,可识别四类实体:地点(LOC)、组织机构(ORG)、人名(PER)和杂项(MISC)
序列标注 英语
B
dslim
1.8M
592
Deid Roberta I2b2
MIT
该模型是基于RoBERTa微调的序列标注模型,用于识别和移除医疗记录中的受保护健康信息(PHI/PII)。
序列标注
Transformers 支持多种语言

D
obi
1.1M
33
Ner English Fast
Flair自带的英文快速4类命名实体识别模型,基于Flair嵌入和LSTM-CRF架构,在CoNLL-03数据集上达到92.92的F1分数。
序列标注
PyTorch 英语
N
flair
978.01k
24
French Camembert Postag Model
基于Camembert-base的法语词性标注模型,使用free-french-treebank数据集训练
序列标注
Transformers 法语

F
gilf
950.03k
9
Xlm Roberta Large Ner Spanish
基于XLM-Roberta-large架构微调的西班牙语命名实体识别模型,在CoNLL-2002数据集上表现优异。
序列标注
Transformers 西班牙语

X
MMG
767.35k
29
Nusabert Ner V1.3
MIT
基于NusaBert-v1.3在印尼语NER任务上微调的命名实体识别模型
序列标注
Transformers 其他

N
cahya
759.09k
3
Ner English Large
Flair框架内置的英文4类大型NER模型,基于文档级XLM-R嵌入和FLERT技术,在CoNLL-03数据集上F1分数达94.36。
序列标注
PyTorch 英语
N
flair
749.04k
44
Punctuate All
MIT
基于xlm-roberta-base微调的多语言标点符号预测模型,支持12种欧洲语言的标点符号自动补全
序列标注
Transformers

P
kredor
728.70k
20
Xlm Roberta Ner Japanese
MIT
基于xlm-roberta-base微调的日语命名实体识别模型
序列标注
Transformers 支持多种语言

X
tsmatz
630.71k
25
精选推荐AI模型
Llama 3 Typhoon V1.5x 8b Instruct
专为泰语设计的80亿参数指令模型,性能媲美GPT-3.5-turbo,优化了应用场景、检索增强生成、受限生成和推理任务
大型语言模型
Transformers 支持多种语言

L
scb10x
3,269
16
Cadet Tiny
Openrail
Cadet-Tiny是一个基于SODA数据集训练的超小型对话模型,专为边缘设备推理设计,体积仅为Cosmo-3B模型的2%左右。
对话系统
Transformers 英语

C
ToddGoldfarb
2,691
6
Roberta Base Chinese Extractive Qa
基于RoBERTa架构的中文抽取式问答模型,适用于从给定文本中提取答案的任务。
问答系统 中文
R
uer
2,694
98