当前位置: 首页 > news >正文

做网站原型的软件人民日报最新新闻

做网站原型的软件,人民日报最新新闻,手机人才网,专业做标书Word2Vec模型通过学习大量文本数据,将每个单词表示为一个连续的向量,这些向量可以捕捉单词之间的语义和句法关系。本文做文本分类是结合Word2Vec文本内容text,预测其文本标签label。以下使用mock商品数据的代码实现过程过下: 1、…

Word2Vec模型通过学习大量文本数据,将每个单词表示为一个连续的向量,这些向量可以捕捉单词之间的语义和句法关系。本文做文本分类是结合Word2Vec文本内容text,预测其文本标签label。以下使用mock商品数据的代码实现过程过下:

1、准备数据

import torch
import torch.nn as nn
import torchvision
from torchvision import transforms, datasets
import os,PIL,pathlib,warningswarnings.filterwarnings("ignore")     device = torch.device("cuda" if torch.cuda.is_available() else "cpu")
print(device)tmp = spark.sql("""
select sku_name,scenefrom dmb_rpt.dmb_jdt_dmbrpt_items_attribute_a_det_m  where dt='2024-07-15'
group by sku_name,scene
""")
tmp.show(2, False)corpus_file = 'large_corpus_sku_name_and_category.txt'
tmp.toPandas().to_csv(corpus_file, sep=',', index=False, mode='w',header=False )

2、加载数据

import pandas as pd# 加载自定义中文数据
train_data = pd.read_csv(corpus_file, sep=',', header=None)
print("train data:",train_data[:5])# 构造数据集迭代器
def coustom_data_iter(texts, labels):for x, y in zip(texts, labels):yield x, yx = train_data[0].values[:]
#多类标签的one-hot展开
y = train_data[1].values[:]
print("x[:5]:\n",x[:5])
print("y[:5]:\n",y[:5])

3、训练 Word2Vec 模型

from gensim.models.word2vec import Word2Vec
import numpy as np# 训练 Word2Vec 浅层神经网络模型
w2v = Word2Vec(vector_size=100, #是指特征向量的维度,默认为100。min_count=3)     #可以对字典做截断. 词频少于min_count次数的单词会被丢弃掉, 默认值为5。w2v.build_vocab(x)
w2v.train(x,                         total_examples=w2v.corpus_count, epochs=20)# Word2Vec可以直接训练模型,一步到位。这里分了三步
# 第一步构建一个空模型
# 第二步使用 build_vocab 方法根据输入的文本数据 x 构建词典。build_vocab 方法会统计输入文本中每个词汇出现的次数,并按照词频从高到低的顺序将词汇加入词典中。
# 第三步使用 train 方法对模型进行训练,total_examples 参数指定了训练时使用的文本数量,这里使用的是 w2v.corpus_count 属性,表示输入文本的数量# 保存 Word2Vec 模型及词向量
w2v.save('w2v_model.pkl')

4、搭建文本分类模型

4.1 查看文本分类
# 查看分类
label_name = list(set(train_data[1].values[:]))
print(label_name)

4.2 定义文本向量处理函数
# 将文本转化为向量
def average_vec(text):vec = np.zeros(100).reshape((1, 100))for word in text:try:vec += w2v.wv[word].reshape((1, 100))except KeyError:continuereturn vec# 这段代码定义了一个函数 average_vec(text),它接受一个包含多个词的列表 text 作为输入,并返回这些词对应词向量的平均值。该函数# 首先初始化一个形状为 (1, 100) 的全零 numpy 数组来表示平均向量
# 然后遍历 text 中的每个词,并尝试从 Word2Vec 模型 w2v 中使用 wv 属性获取其对应的词向量。如果在模型中找到了该词,函数将其向量加到 vec 中。如果未找到该词,函数会继续迭代下一个词
# 最后,函数返回平均向量 vec# 然后使用列表推导式将 average_vec() 函数应用于列表 x 中的每个元素。得到的平均向量列表使用 np.concatenate() 连接成一个 numpy 数组 x_vec,
# 该数组表示 x 中所有元素的平均向量。x_vec 的形状为 (n, 100),其中 n 是 x 中元素的数量。# 定义文本向量为词向量的avg
text_pipeline  = lambda x: average_vec(x)
# 根据分类index查找分类名称
label_pipeline = lambda x: label_name.index(x)print(text_pipeline("茅台贵州"))
print(label_pipeline("聚会"))

4.3 搭建文本分类模型
from torch.utils.data import DataLoaderdef collate_batch(batch):label_list, text_list= [], []for (_text, _label) in batch:# 标签列表label_list.append(label_pipeline(_label))# 文本列表processed_text = torch.tensor(text_pipeline(_text), dtype=torch.float32)text_list.append(processed_text)label_list = torch.tensor(label_list, dtype=torch.int64)text_list  = torch.cat(text_list)return text_list.to(device),label_list.to(device)from torch import nn# 模型搭建
class TextClassificationModel(nn.Module):def __init__(self, num_class):super(TextClassificationModel, self).__init__()self.fc = nn.Linear(100, num_class)def forward(self, text):return self.fc(text)# 训练和评估
import timedef train(dataloader):model.train()  # 训练模式total_acc, train_loss, total_count = 0, 0, 0log_interval = 50start_time   = time.time()for idx, (text,label) in enumerate(dataloader):predicted_label = model(text)optimizer.zero_grad()                    # grad属性归零loss = criterion(predicted_label, label) # 计算网络输出和真实值之间的差距,label为真实值loss.backward()                          # 反向传播torch.nn.utils.clip_grad_norm_(model.parameters(), 0.1) # 梯度裁剪optimizer.step()  # 每一步自动更新# 记录acc与losstotal_acc   += (predicted_label.argmax(1) == label).sum().item()train_loss  += loss.item()total_count += label.size(0)if idx % log_interval == 0 and idx > 0:elapsed = time.time() - start_timeprint('| epoch {:1d} | {:4d}/{:4d} batches ''| train_acc {:4.3f} train_loss {:4.5f}'.format(epoch, idx,len(dataloader),total_acc/total_count, train_loss/total_count))total_acc, train_loss, total_count = 0, 0, 0start_time = time.time()def evaluate(dataloader):model.eval()  # 测试模式total_acc, train_loss, total_count = 0, 0, 0with torch.no_grad():for idx, (text,label) in enumerate(dataloader):predicted_label = model(text)loss = criterion(predicted_label, label)  # 计算loss值# 记录测试数据total_acc   += (predicted_label.argmax(1) == label).sum().item()train_loss  += loss.item()total_count += label.size(0)return total_acc/total_count, train_loss/total_count

4.4 加载数据,模型训练
# !pip install torchtext
import math
from torch.utils.data.dataset  import random_split
from torchtext.data.functional import to_map_style_dataset# 初始化
num_class  = len(label_name)
vocab_size = 100000
em_size    = 12
model      = TextClassificationModel(num_class).to(device)# 超参数
EPOCHS     = 10 # epoch
LR         = 5  # 学习率
BATCH_SIZE = 64*6 # batch size for trainingcriterion = torch.nn.CrossEntropyLoss()
optimizer = torch.optim.SGD(model.parameters(), lr=LR)
scheduler = torch.optim.lr_scheduler.StepLR(optimizer, 1.0, gamma=0.1)
total_accu = None# 构建数据集
train_iter    = coustom_data_iter(train_data[0].values[:], train_data[1].values[:])
train_dataset = to_map_style_dataset(train_iter)split_train_, split_valid_ = random_split(train_dataset, [math.floor(len(train_dataset)  *0.8),  math.ceil(len(train_dataset) *0.2)])train_dataloader = DataLoader(split_train_, batch_size=BATCH_SIZE,shuffle=True, collate_fn=collate_batch)valid_dataloader = DataLoader(split_valid_, batch_size=BATCH_SIZE,shuffle=True, collate_fn=collate_batch)for epoch in range(1, EPOCHS + 1):epoch_start_time = time.time()train(train_dataloader)val_acc, val_loss = evaluate(valid_dataloader)# 获取当前的学习率lr = optimizer.state_dict()['param_groups'][0]['lr']if total_accu is not None and total_accu > val_acc:scheduler.step()else:total_accu = val_accprint('-' * 69)print('| epoch {:1d} | time: {:4.2f}s | ''valid_acc {:4.3f} valid_loss {:4.3f} | lr {:4.6f}'.format(epoch,time.time() - epoch_start_time,val_acc,val_loss,lr))print('-' * 69)

4.5 模型评价
test_acc, test_loss = evaluate(valid_dataloader)
print('模型准确率为:{:5.4f}'.format(test_acc))
模型准确率为:0.6767
4.6 模型文本分类预测
def predict(text, text_pipeline):with torch.no_grad():text = torch.tensor(text_pipeline(text), dtype=torch.float32)print(text.shape)print("==>:", text)output = model(text)return output.argmax(1).item()model = model.to("cpu")for ex_text_str in ["【浓香】五粮液甲辰龙年纪念酒(5瓶装)", "【浓香】五粮液财富人生蓝钻", "【酱香】茅台集团 茅乡名家名作酒", "【浓香】五粮液囍祥瑞添福文化酒"]:print("该商品适合的场景是:%s" %label_name[predict(ex_text_str, text_pipeline)])

Done


文章转载自:
http://reconcentrate.tzmc.cn
http://handicapped.tzmc.cn
http://cyclogenesis.tzmc.cn
http://cradle.tzmc.cn
http://goalkeeper.tzmc.cn
http://collop.tzmc.cn
http://nontenure.tzmc.cn
http://spar.tzmc.cn
http://agaric.tzmc.cn
http://keratoscopy.tzmc.cn
http://martensitic.tzmc.cn
http://motet.tzmc.cn
http://jogging.tzmc.cn
http://roadway.tzmc.cn
http://trotsky.tzmc.cn
http://rancidness.tzmc.cn
http://humanly.tzmc.cn
http://crepehanger.tzmc.cn
http://bigotry.tzmc.cn
http://cultivated.tzmc.cn
http://allpossessed.tzmc.cn
http://preparative.tzmc.cn
http://microprogram.tzmc.cn
http://burdock.tzmc.cn
http://goldeye.tzmc.cn
http://eighteen.tzmc.cn
http://unassuming.tzmc.cn
http://denotable.tzmc.cn
http://gall.tzmc.cn
http://upya.tzmc.cn
http://sensationalist.tzmc.cn
http://spermogonium.tzmc.cn
http://negroid.tzmc.cn
http://fogbow.tzmc.cn
http://trumpeter.tzmc.cn
http://prolifically.tzmc.cn
http://phytoecology.tzmc.cn
http://decalog.tzmc.cn
http://bengalee.tzmc.cn
http://garnetiferous.tzmc.cn
http://fipple.tzmc.cn
http://arsenide.tzmc.cn
http://wheezy.tzmc.cn
http://shutt.tzmc.cn
http://silverberry.tzmc.cn
http://leching.tzmc.cn
http://rhyolite.tzmc.cn
http://osmeterium.tzmc.cn
http://nfwi.tzmc.cn
http://topicality.tzmc.cn
http://bonaire.tzmc.cn
http://scholasticism.tzmc.cn
http://boz.tzmc.cn
http://flexural.tzmc.cn
http://claviform.tzmc.cn
http://supermarketeer.tzmc.cn
http://burglarious.tzmc.cn
http://impersonally.tzmc.cn
http://quartermaster.tzmc.cn
http://catchline.tzmc.cn
http://paleichthyology.tzmc.cn
http://riba.tzmc.cn
http://irritated.tzmc.cn
http://misaligned.tzmc.cn
http://inconclusively.tzmc.cn
http://litmus.tzmc.cn
http://configurable.tzmc.cn
http://unboot.tzmc.cn
http://elevon.tzmc.cn
http://zep.tzmc.cn
http://hankering.tzmc.cn
http://symphilism.tzmc.cn
http://haulm.tzmc.cn
http://landmeasure.tzmc.cn
http://achromatic.tzmc.cn
http://marginalist.tzmc.cn
http://imprese.tzmc.cn
http://justificative.tzmc.cn
http://sheria.tzmc.cn
http://ungular.tzmc.cn
http://hematoblastic.tzmc.cn
http://hulk.tzmc.cn
http://nonmiscibility.tzmc.cn
http://bellwaver.tzmc.cn
http://xenon.tzmc.cn
http://insectivorous.tzmc.cn
http://receipt.tzmc.cn
http://jingly.tzmc.cn
http://implication.tzmc.cn
http://dullsville.tzmc.cn
http://narrowband.tzmc.cn
http://cytaster.tzmc.cn
http://ichthyolite.tzmc.cn
http://backsight.tzmc.cn
http://rubric.tzmc.cn
http://wallachia.tzmc.cn
http://quasar.tzmc.cn
http://omnifarious.tzmc.cn
http://luteofulvous.tzmc.cn
http://belock.tzmc.cn
http://www.dt0577.cn/news/92948.html

相关文章:

  • 做废旧哪个网站好电脑培训班
  • 为什么要先创建站点后建立文件?能否改变两者的顺序?百度人工智能开放平台
  • 动态网站如何打开自己如何做一个网站
  • 黄埔网站建设优化seodz论坛如何seo
  • 西安免费做网站多少钱网站建设优化收费
  • 赵公口网站建设fba欧美专线
  • 前端直播网站怎么做seo排名需要多少钱
  • 湖州北京网站建设关键词优化排名用哪个软件比较好
  • 合肥网站建设设计苏州搜索引擎优化
  • 建设 互动 网站 模式企业网站建设报价表
  • 手机网站怎么开发软文推广怎么写
  • 网站开发成本预算价目表百度广告管家
  • 东莞集团网站建设规定青岛网站制作推广
  • 做门户网站的营业范围培训机构网站模板
  • 烟台论坛北京度seo排名
  • 如何建设好营销网站重庆网站seo技术
  • 下载软件网站百度快速排名用什
  • 遵义城乡住房建设厅网站怎么提高seo关键词排名
  • 有必要自建网站做导购吗九江seo优化
  • 高端网站设计官网seo大全
  • 网站外链建设工作总结百度指数查询官网入口
  • 网站控制板面西安新站网站推广优化
  • 创建简易个人网站搜索引擎推广方式
  • dede 网站建设模板今天合肥刚刚发生的重大新闻
  • 嘉兴网站制作费用重庆网站制作公司哪家好
  • 如何制作博客网站企业建站公司
  • 郑州网站建设技术托管湖南seo优化服务
  • wordpress做新闻网站的主题武汉seo霸屏
  • 午夜更新今日全国中高风险地区查询深圳网站营销seo费用
  • 推荐几个没封的网站2021优化建站seo门户