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

红酒公司网站源码电商网站前端模板

红酒公司网站源码,电商网站前端模板,东莞做网站找微客巴巴,百度做网站审核要多久前言 意图识别#xff08;Intent Recognition#xff09;是自然语言处理#xff08;NLP#xff09;中的一个重要任务#xff0c;它旨在确定用户输入的语句中所表达的意图或目的。简单来说#xff0c;意图识别就是对用户的话语进行语义理解#xff0c;以便更好地回答用户…前言 意图识别Intent Recognition是自然语言处理NLP中的一个重要任务它旨在确定用户输入的语句中所表达的意图或目的。简单来说意图识别就是对用户的话语进行语义理解以便更好地回答用户的问题或提供相关的服务。 在NLP中意图识别通常被视为一个分类问题即通过将输入语句分类到预定义的意图类别中来识别其意图。这些类别可以是各种不同的任务、查询、请求等例如搜索、购买、咨询、命令等。 下面是一个简单的例子来说明意图识别的概念 用户输入 我想订一张从北京到上海的机票。 意图识别预订机票。 在这个例子中通过将用户输入的语句分类到“预订机票”这个意图类别中系统可以理解用户的意图并为其提供相关的服务。 意图识别是NLP中的一项重要任务它可以帮助我们更好地理解用户的需求和意图从而为用户提供更加智能和高效的服务。 在智能对话任务中意图识别是一种非常重要的技术它可以帮助系统理解用户的输入从而提供更加准确和个性化的回答和服务。 模型 意图识别和槽位填充是对话系统中的基础任务。本仓库实现了一个基于BERT的意图intent和槽位slots联合预测模块。想法上实际与JoinBERT类似GitHubBERT for Joint Intent Classification and Slot Filling利用 [CLS] token对应的last hidden state去预测整句话的intent并利用句子tokens的last hidden states做序列标注找出包含slot values的tokens。你可以自定义自己的意图和槽位标签并提供自己的数据通过下述流程训练自己的模型并在JointIntentSlotDetector类中加载训练好的模型直接进行意图和槽值预测。 源GitHubhttps://github.com/Linear95/bert-intent-slot-detector 在本文使用的模型中对数据进行了扩充、对代码进行注释、对部分代码进行了修改。 Bert模型下载 Bert模型下载地址https://huggingface.co/bert-base-chinese/tree/main 下载下方红框内的模型即可。 数据集介绍 训练数据以json格式给出每条数据包括三个关键词text表示待检测的文本intent代表文本的类别标签slots是文本中包括的所有槽位以及对应的槽值以字典形式给出。 { text: 搜索西红柿的做法。, domain: cookbook, intent: QUERY, slots: {ingredient: 西红柿} } 原始数据集https://conference.cipsc.org.cn/smp2019/ 本项目中在原始数据集中新增了部分数据用来平衡数据。 模型训练 python train.py # -----------training------------- max_acc 0 for epoch in range(args.train_epochs):total_loss 0model.train()for step, batch in enumerate(train_dataloader):input_ids, intent_labels, slot_labels batchoutputs model(input_idstorch.tensor(input_ids).long().to(device),intent_labelstorch.tensor(intent_labels).long().to(device),slot_labelstorch.tensor(slot_labels).long().to(device))loss outputs[loss]total_loss loss.item()if args.gradient_accumulation_steps 1:loss loss / args.gradient_accumulation_stepsloss.backward()if step % args.gradient_accumulation_steps 0:# 用于对梯度进行裁剪以防止在神经网络训练过程中出现梯度爆炸的问题。torch.nn.utils.clip_grad_norm_(model.parameters(), args.max_grad_norm)optimizer.step()scheduler.step()model.zero_grad()train_loss total_loss / len(train_dataloader)dev_acc, intent_avg, slot_avg dev(model, val_dataloader, device, slot_dict)flag Falseif max_acc dev_acc:max_acc dev_accflag Truesave_module(model, model_save_dir)print(f[{epoch}/{args.train_epochs}] train loss: {train_loss} dev intent_avg: {intent_avg} fdef slot_avg: {slot_avg} save best model: {* if flag else })dev_acc, intent_avg, slot_avg dev(model, val_dataloader, device, slot_dict) print(last model dev intent_avg: {} def slot_avg: {}.format(intent_avg, slot_avg)) 运行过程 模型推理 python predict.py def detect(self, text, str_lower_caseTrue):text : list of string, each string is a utterance from userlist_input Trueif isinstance(text, str):text [text]list_input Falseif str_lower_case:text [t.lower() for t in text]batch_size len(text)inputs self.tokenizer(text, paddingTrue)with torch.no_grad():outputs self.model(input_idstorch.tensor(inputs[input_ids]).long().to(self.device))intent_logits outputs[intent_logits]slot_logits outputs[slot_logits]intent_probs torch.softmax(intent_logits, dim-1).detach().cpu().numpy()slot_probs torch.softmax(slot_logits, dim-1).detach().cpu().numpy()slot_labels self._predict_slot_labels(slot_probs)intent_labels self._predict_intent_labels(intent_probs)slot_values self._extract_slots_from_labels(inputs[input_ids], slot_labels, inputs[attention_mask])outputs [{text: text[i], intent: intent_labels[i], slots: slot_values[i]}for i in range(batch_size)]if not list_input:return outputs[0]return outputs 推理结果 模型检测相关代码 将概率值转换为实际标注值 def _predict_slot_labels(self, slot_probs):slot_probs : probability of a batch of tokens into slot labels, [batch, seq_len, slot_label_num], numpy arrayslot_ids np.argmax(slot_probs, axis-1)return self.slot_dict[slot_ids.tolist()]def _predict_intent_labels(self, intent_probs):intent_labels : probability of a batch of intent ids into intent labels, [batch, intent_label_num], numpy arrayintent_ids np.argmax(intent_probs, axis-1)return self.intent_dict[intent_ids.tolist()] 槽位验证确保检测结果的正确性 def _extract_slots_from_labels_for_one_seq(self, input_ids, slot_labels, maskNone):results {}unfinished_slots {} # dict of {slot_name: slot_value} pairsif mask is None:mask [1 for _ in range(len(input_ids))]def add_new_slot_value(results, slot_name, slot_value):if slot_name or slot_value :return resultsif slot_name in results:results[slot_name].append(slot_value)else:results[slot_name] [slot_value]return resultsfor i, slot_label in enumerate(slot_labels):if mask[i] 0:continue# 检测槽位的第一字符B_开头if slot_label[:2] B_:slot_name slot_label[2:] # 槽位名称 B_ 后面if slot_name in unfinished_slots:results add_new_slot_value(results, slot_name, unfinished_slots[slot_name])unfinished_slots[slot_name] self.tokenizer.decode(input_ids[i])# 检测槽位的后面字符I_开头elif slot_label[:2] I_:slot_name slot_label[2:]if slot_name in unfinished_slots and len(unfinished_slots[slot_name]) 0:unfinished_slots[slot_name] self.tokenizer.decode(input_ids[i])for slot_name, slot_value in unfinished_slots.items():if len(slot_value) 0:results add_new_slot_value(results, slot_name, slot_value)return results 源码获取 NLP/bert-intent-slot at main · mzc421/NLP (github.com)https://github.com/mzc421/NLP/tree/main/bert-intent-slot 链接作者 欢迎关注我的公众号AI算法与电子竞赛 硬性的标准其实限制不了无限可能的我们所以啊少年们加油吧
http://www.hkea.cn/news/14344724/

相关文章:

  • dnn wordpress网站优化目的
  • 盐城网站开发渠道合作网站建设与维护的试卷
  • 北京平台网站建设哪里好新公司网站怎么做推广
  • 个人设计网站模板vs网站搜索栏怎么做
  • 5173游戏交易网站源码河北明迈特的网站在哪里做的
  • 中国建设银行手机wap网站建设网站技术要求
  • sqlite 做网站数据库创新型的赣州网站建设
  • 台州做企业网站wordpress 开源插件
  • 北京律师网站建设wordpress添加会员等级标识
  • 新手怎样学校做网站企业宣传视频制作免费版
  • 网站域名转发wordpress的注册文件
  • 网站留言系统 提交没反应360网站做二维码
  • 网站左侧漂浮代码沧州推广建站
  • 湖南营销型网站建设报价wordpress 制作论坛
  • 专业电商网站建设价格温州建校特种作业人员查询
  • 时光轴网站模板企业信息填报报送年度报告
  • 网站怎样备案毕设做网站答辩会要求当场演示吗
  • 个人网站建立邮箱注册网站申请
  • 上海网络营销有限公司seo搜索引擎是什么意思
  • 找人做网站推广做网站必须学php吗
  • 合肥营销型网站建设公司杭州建设主管部门的网站
  • 建设网站需要什么软件东莞品牌做网站
  • 一个网站如何挣钱花钱做网站不给源码
  • 电子商务网站建设教材网站建设完工报告
  • 济宁网站建设seo阳朔到桂林大巴时刻表
  • 可以做微网站的第三方平台无锡做企业网站
  • 住房建设局网站iis不能新建网站
  • 云南网站设计方案大象戌人视频入口2022
  • 平度市网站建设网站建设包含那些 内容
  • 网站基本信息设置长沙app软件制作