基于内容的电影推荐:物品画像(基于tf-idf)、用户画像及推荐结果

1. 基于内容的推荐算法

基于内容的推荐算法非常直接,它以物品的内容描述信息为依据所做出的的推荐,本质上是基于对物品和用户自身的特征或属性的直接分析和计算。

2. 基于内容的推荐实现步骤

  • 画像构建。画像就是刻画物品或用户的特征。本质上就是给用户或物品贴标签。
    • 物品画像
    • 用户画像

2.1 物品的标签来自哪儿?

  • PCG (Platform and Content Group) 物品画像冷启动

    • 物品自带的属性(物品一产生就具备的):如电影的标题、导演、演员、类型等等;
    • 服务提供方设定的属性服务提供方为物品附加的属性):如短视频话题、微博话题(平台拟定)
  • UGC (User Generated Content) 冷启动问题

    • 用户在享受服务过程中提供的物品的属性:如用户评论内容,微博话题(用户拟定)

根据PGC内容构建的物品画像的可以解决物品的冷启动问题

2.2 基于内容推荐的算法流程

  • 根据PGC/UGC内容构建物品画像
  • 根据用户行为记录生成用户画像
  • 根据用户画像从物品中寻找最匹配的TOP-N物品进行推荐

2.3 物品冷启动处理

  • 根据PGC内容构建物品画像
  • 利用物品画像计算物品间两两相似情况
  • 为每个物品产生TOP-N最相似的物品进行相关推荐:与该商品相似的商品有哪些?与该文章相似的文章有哪些?

一、基于内容的电影推荐:物品画像构建步骤

  • 利用tags.csv中每部电影的标签作为电影的候选关键词
  • 利用TF-IDF计算每部电影的标签的tf-idf值,选取top-N个关键词作为电影画像标签
  • 将电影的分类词直接作为每部电影的画像标签

3.1 基于TF-IDF的特征提取技术

物品画像的特征标签主要都是指的如电影的导演、演员、图书的作者、出版社等结构话的数据,也就是他们的特征提取,尤其是体征向量的计算是比较简单的,如直接给作品的分类定义0或者1的状态。

但另外一些特征,比如电影的内容简介、电影的影评、图书的摘要等文本数据,这些被称为非结构化数据,首先他们本应该也属于物品的一个特征标签,但是这样的特征标签进行量化时,也就是计算它的特征向量时是很难去定义的。

因此这时就需要借助一些自然语言处理、信息检索等技术,将如用户的文本评论或其他文本内容信息的非结构化数据进行量化处理,从而实现更加完善的物品画像/用户画像。

TF-IDF算法便是其中一种在自然语言处理领域中应用比较广泛的一种算法。可用来提取目标文档中,并得到关键词用于计算对于目标文档的权重,并将这些权重组合到一起得到特征向量。

算法原理

TF-IDF自然语言处理领域中计算文档中词或短语的权值的方法,是词频(Term Frequency,TF)和逆转文档频率(Inverse Document Frequency,IDF)的乘积。TF指的是某一个给定的词语在该文件中出现的次数。这个数字通常会被正规化,以防止它偏向长的文件(同一个词语在长文件里可能会比短文件有更高的词频,而不管该词语重要与否)。IDF是一个词语普遍重要性的度量,某一特定词语的IDF,可以由总文件数目除以包含该词语之文件的数目,再将得到的商取对数得到。

TF-IDF算法基于一个这样的假设:若一个词语在目标文档中出现的频率高而在其他文档中出现的频率低,那么这个词语就可以用来区分出目标文档。这个假设需要掌握的有两点:

  • 本文档出现的频率高
  • 其他文档出现的频率低

因此,TF-IDF算法的计算可以分为词频(Term Frequency,TF)和逆转文档频率(Inverse Document Frequency,IDF)两部分,由TF和IDF的乘积来设置文档词语的权重。

TF指的是一个词语在文档中的出现频率。假设文档集包含的文档数为NNN,文档集中包含关键词kik_iki的文档数为nin_inifijf_{ij}fij表示关键词kik_iki在文档djd_jdj中出现的次数,fdjf_{dj}fdj表示文档djd_jdj中出现的词语总数,kik_iki在文档djd_jdj中的词频TFijTF_{ij}TFij定义为:TFij=fijfdjTF_{ij}=\frac {f_{ij}}{f_{dj}}TFij=fdjfij。并且注意,这个数字通常会被正规化,以防止它偏向长的文件(指同一个词语在长文件里可能会比短文件有更高的词频,而不管该词语重要与否)。
IDF是一个词语普遍重要性的度量。表示某一词语在整个文档集中出现的频率,由它计算的结果取对数得到关键词kik_iki的逆文档频率IDFiIDF_iIDFiIDFi=logNniIDF_i=log\frac {N}{n_i}IDFi=logniN
由TF和IDF计算词语的权重为:wij=TFijw_{ij}=TF_{ij}wij=TFij·IDFi=fijfdjIDF_{i}=\frac {f_{ij}}{f_{dj}}IDFi=fdjfij·logNnilog\frac {N}{n_i}logniN

结论:TF-IDF与词语在文档中的出现次数成正比,与该词在整个文档集中的出现次数成反比。

用途:在目标文档中,提取关键词(特征标签)的方法就是将该文档所有词语的TF-IDF计算出来并进行对比,取其中TF-IDF值最大的k个数组成目标文档的特征向量用以表示文档。

注意:文档中存在的停用词(Stop Words),如“是”、“的”之类的,对于文档的中心思想表达没有意义的词,在分词时需要先过滤掉再计算其他词语的TF-IDF值。

算法举例

对于计算影评的TF-IDF,以电影“加勒比海盗:黑珍珠号的诅咒”为例,假设它总共有1000篇影评,其中一篇影评的总词语数为200,其中出现最频繁的词语为“海盗”、“船长”、“自由”,分别是20、15、10次,并且这3个词在所有影评中被提及的次数分别为1000、500、100,就这3个词语作为关键词的顺序计算如下。

  1. 将影评中出现的停用词过滤掉,计算其他词语的词频。以出现最多的三个词为例进行计算如下:

    • “海盗”出现的词频为20/200=0.1
    • “船长”出现的词频为15/200=0.075
    • “自由”出现的词频为10/200=0.05;
  2. 计算词语的逆文档频率如下:

    • “海盗”的IDF为:log(1000/1000)=0
    • “船长”的IDF为:log(1000/500)=0.3
      “自由”的IDF为:log(1000/100)=1
  3. 由1和2计算的结果求出词语的TF-IDF结果,“海盗”为0,“船长”为0.0225,“自由”为0.05。

通过对比可得,该篇影评的关键词排序应为:“自由”、“船长”、“海盗”。把这些词语的TF-IDF值作为它们的权重按照对应的顺序依次排列,就得到这篇影评的特征向量,我们就用这个向量来代表这篇影评,向量中每一个维度的分量大小对应这个属性的重要性。

将总的影评集中所有的影评向量与特定的系数相乘求和,得到这部电影的综合影评向量,与电影的基本属性结合构建视频的物品画像,同理构建用户画像,可采用多种方法计算物品画像和用户画像之间的相似度,为用户做出推荐。

3.2 算法实现

加载数据集

import pandas as pd
import numpy as np"""
利用tags.csv中每部电影的标签作为电影的候选关键词,利用TF-IDF计算每部电影的标签的tf-idf值,选取Top-N个
关键词作为电影画像标签,并将电影的分类词直接作为每部电影的画像标签。
"""def get_movie_dataset():# 加载基于所有电影的标签,all-tag.csv来自ml-latest数据集中_tags = pd.read_csv("tags_all.csv", index_col="movieId", usecols=range(1, 3)).dropna()tags = _tags.groupby("movieId").agg(list)# 加载电影列表数据集movies = pd.read_csv("movies.csv", index_col="movieId")# 将类别词分开movies["genres"] = movies["genres"].apply(lambda x: x.split("|"))# 为每部电影匹配对应的标签数据,如果没有将会使nanmovies_index = set(movies.index) & set(tags.index)new_tags = tags.loc[list(movies_index)]ret = movies.join(new_tags)"""构建电影数据集,包含电影id、电影名称、类别、标签四个字段如果电影没有标签数据,那么就替换为空列表,map(fun,可迭代对象)"""movie_dataset = pd.DataFrame(map(lambda x: (x[0], x[1], x[2], x[2] + x[3]) if x[3] is not np.nan else (x[0], x[1], x[2], []), ret.itertuples()), columns=["movieId", "title", "genres", "tags"])movie_dataset.set_index("movieId", inplace=True)return movie_dataset

基于TF-IDF提取top-N关键词,构建电影画像

from gensim.models import TfidfModel
from gensim.corpora import Dictionary
from pprint import pprintdef create_movie_profile(movie_dataset):"""使用tfidf,分析提取topn关键字:param movie_dataset: 电影数据集-电影id,电影名,分类,标签:return: 电影画像"""dataset = movie_dataset["tags"].values# 根据数据集建立词袋,并统计词频,将所有词放入一个词典,使用索引进行获取dct = Dictionary(dataset)corpus = [dct.doc2bow(line) for line in dataset]# 训练TF-IDF模型,即计算TD-IDF值model = TfidfModel(corpus)_movie_profile = []for i, data in enumerate(movie_dataset.itertuples()):mid = data[0]title = data[1]genres = data[2]vector = model[corpus[i]]movie_tags = sorted(vector, key=lambda x: x[1], reverse=True)[:30]topN_tags_weights = dict(map(lambda x: (dct[x[0]], x[1]), movie_tags))# 将类别词添加进去,并设置权重值为1for g in genres:topN_tags_weights[g] = 1topN_tags = [i[0] for i in topN_tags_weights.items()]_movie_profile.append((mid, title, topN_tags, topN_tags_weights))movie_profile = pd.DataFrame(_movie_profile, columns=["movieId", "title", "profile", "weights"])movie_profile.set_index("movieId", inplace=True)return movie_profile

倒排索引(根据指定关键词迅速匹配到对应的电影)

def create_inverted_table(movie_profile):inverted_table = {}for mid, weights in movie_profile["weights"].iteritems():for tag, weight in weights.items():# 到inverted_table字典中用tag作为key取值,如果取不到返回[]_ = inverted_table.get(tag, [])_.append((mid, weight))inverted_table.setdefault(tag, _)return inverted_tableif __name__ == "__main__":movieDataset = get_movie_dataset()movieProfile = create_movie_profile(movieDataset)pprint(movieProfile)pprint(create_inverted_table(movieProfile))

二、基于内容的电影推荐:用户画像

1.电影推荐用户画像构建步骤

  • 根据用户的评分历史,结合物品画像,将有观影记录的电影的画像标签作为初始标签反打到用户身上
  • 通过对用户观影标签的次数进行统计,计算用户的每个初始标签的权重值,排序后选取top-n作为用户最终的画像标签

2. 用户画像建立

import pandas as pd
import numpy as np
from gensim.models import TfidfModelfrom functools import reduce
import collectionsfrom pprint import pprint"""
user profile画像建立:
1. 提取用户观看列表
2. 根据观看列表和物品画像为用户匹配关键词,并统计词频
3. 根据词频顺序,最多保留topK个词,设k为50,作为用户的标签
"""def create_user_profile():watch_record = pd.read_csv("ratings.csv", usecols=range(2), dtype={"userId": np.int32, "movieId": np.int32})watch_record = watch_record.groupby("userId").agg(list)movie_dataset = get_movie_dataset()movie_profile = create_movie_profile(movie_dataset)user_profile = {}for uid, mids in watch_record.itertuples():record_movie_profile = movie_profile.loc[list(mids)]counter = collections.Counter(reduce(lambda x, y: list(x) + list(y), record_movie_profile["profile"].values))# 最感兴趣的前50个词interset_words = counter.most_common(50)maxcount = interset_words[0][1]interset_words = [(w, round(c / maxcount, 4)) for w, c in interset_words]user_profile[uid] = interset_wordsreturn user_profileif __name__ == "__main__":userProfile = create_user_profile()pprint(userProfile)

三、为用户产生top-N推荐结果

def give_results(user_profile, inverted_tables):# 每位用户推荐的10部电影id以及相应的关键词权重和all_result = {}for uid, interest_words in user_profile.items():result_table = {}for interest_word, interest_weight in interest_words:related_movies = inverted_tables[interest_word]for mid, related_weight in related_movies:_ = result_table.get(mid, [])_.append(interest_weight)result_table.setdefault(mid, _)rs_result = map(lambda x: (x[0], round(sum(x[1]), 2)), result_table.items())rs_result = sorted(rs_result, key=lambda x: x[1], reverse=True)[:10]all_result.setdefault(uid, rs_result)return all_resultif __name__ == "__main__":movieDataset = get_movie_dataset()movieProfile = create_movie_profile(movieDataset)invertedTable = create_inverted_table(movieProfile)userProfile = create_user_profile()rsResult = give_results(userProfile, invertedTable)print(rsResult)

四、整体流程回顾

  1. 建立物品画像
  • ①用户打tag②电影的分类值
  • 根据电影的id把tag和分类值合并起来求tf-idf
  • 根据tf-idf的结果为每一部电影筛选出top-n(tf-idf比较大)个关键词
  • 最后得到【电影id,电影名称,电影关键词,关键词权重】[“movieId”, “title”, “profile”, “weights”]
  1. 建立倒排索引
  • 通过关键词找到电影
  • 遍历用户画像的【电影关键词】([“profile”])数据,读取每一个关键词和关键词权重,将关键词作为键,列表作为值,列表中存储着每个电影及该关键词在该部电影中的权重值大小。
  1. 用户画像
  • 查看用户看过哪些电影,在物品画像中找到用户看过的电影的关键词
  • 统计关键词的词频
  • 统计出现最多的前n个关键词作为用户画像的关键词
  1. 根据用户的关键词,找到关键词对应的电影,多个关键词可能对应一个电影【电影id:【关键词1权重,关键词2权重】】
  • 把每一部电影对应的关键词权重求和之后,排序比较高的排在前面推荐给用户。

整体代码

import pandas as pd
import numpy as np
from gensim.models import TfidfModel
from gensim.corpora import Dictionary
from functools import reduce
import collections"""
利用tags.csv中每部电影的标签作为电影的候选关键词,利用TF-IDF计算每部电影的标签的tf-idf值,选取Top-N个
关键词作为电影画像标签,并将电影的分类词直接作为每部电影的画像标签。
"""def get_movie_dataset():# 加载基于所有电影的标签,all-tag.csv来自ml-latest数据集中_tags = pd.read_csv("tags_all.csv", index_col="movieId", usecols=range(1, 3)).dropna()tags = _tags.groupby("movieId").agg(list)# 加载电影列表数据集movies = pd.read_csv("movies.csv", index_col="movieId")# 将类别词分开movies["genres"] = movies["genres"].apply(lambda x: x.split("|"))# 为每部电影匹配对应的标签数据,如果没有将会使nanmovies_index = set(movies.index) & set(tags.index)new_tags = tags.loc[list(movies_index)]ret = movies.join(new_tags)"""构建电影数据集,包含电影id、电影名称、类别、标签四个字段如果电影没有标签数据,那么就替换为空列表,map(fun,可迭代对象)"""movie_dataset = pd.DataFrame(map(lambda x: (x[0], x[1], x[2], x[2] + x[3]) if x[3] is not np.nanelse (x[0], x[1], x[2], []), ret.itertuples()), columns=["movieId", "title", "genres", "tags"])movie_dataset.set_index("movieId", inplace=True)return movie_datasetdef create_movie_profile(movie_dataset):"""使用tfidf,分析提取topn关键字:param movie_dataset: 电影数据集-电影id,电影名,分类,标签:return: 电影画像"""dataset = movie_dataset["tags"].values# 根据数据集建立词袋,并统计词频,将所有词放入一个词典,使用索引进行获取dct = Dictionary(dataset)corpus = [dct.doc2bow(line) for line in dataset]# 训练TF-IDF模型,即计算TD-IDF值model = TfidfModel(corpus)_movie_profile = []for i, data in enumerate(movie_dataset.itertuples()):mid = data[0]title = data[1]genres = data[2]vector = model[corpus[i]]movie_tags = sorted(vector, key=lambda x: x[1], reverse=True)[:30]topN_tags_weights = dict(map(lambda x: (dct[x[0]], x[1]), movie_tags))# 将类别词添加进去,并设置权重值为1for g in genres:topN_tags_weights[g] = 1topN_tags = [i[0] for i in topN_tags_weights.items()]_movie_profile.append((mid, title, topN_tags, topN_tags_weights))movie_profile = pd.DataFrame(_movie_profile, columns=["movieId", "title", "profile", "weights"])movie_profile.set_index("movieId", inplace=True)return movie_profiledef create_inverted_table(movie_profile):inverted_table = {}for mid, weights in movie_profile["weights"].iteritems():for tag, weight in weights.items():# 到inverted_table字典中用tag作为key取值,如果取不到返回[]_ = inverted_table.get(tag, [])_.append((mid, weight))inverted_table.setdefault(tag, _)return inverted_table"""
user profile画像建立:
1. 提取用户观看列表
2. 根据观看列表和物品画像为用户匹配关键词,并统计词频
3. 根据词频顺序,最多保留topK个词,设k为50,作为用户的标签
"""def create_user_profile():watch_record = pd.read_csv("ratings.csv", usecols=range(2), dtype={"userId": np.int32, "movieId": np.int32})watch_record = watch_record.groupby("userId").agg(list)movie_dataset = get_movie_dataset()movie_profile = create_movie_profile(movie_dataset)user_profile = {}for uid, mids in watch_record.itertuples():record_movie_profile = movie_profile.loc[list(mids)]counter = collections.Counter(reduce(lambda x, y: list(x) + list(y), record_movie_profile["profile"].values))# 最感兴趣的前50个词interset_words = counter.most_common(50)maxcount = interset_words[0][1]interset_words = [(w, round(c / maxcount, 4)) for w, c in interset_words]user_profile[uid] = interset_wordsreturn user_profiledef give_results(user_profile, inverted_tables):# 每位用户推荐的10部电影id以及相应的关键词权重和all_result = {}for uid, interest_words in user_profile.items():result_table = {}for interest_word, interest_weight in interest_words:related_movies = inverted_tables[interest_word]for mid, related_weight in related_movies:_ = result_table.get(mid, [])_.append(interest_weight)result_table.setdefault(mid, _)rs_result = map(lambda x: (x[0], round(sum(x[1]), 2)), result_table.items())rs_result = sorted(rs_result, key=lambda x: x[1], reverse=True)[:10]all_result.setdefault(uid, rs_result)return all_resultif __name__ == "__main__":movieDataset = get_movie_dataset()movieProfile = create_movie_profile(movieDataset)invertedTable = create_inverted_table(movieProfile)userProfile = create_user_profile()allResult = give_results(userProfile, invertedTable)print(allResult)
查看全文
如若内容造成侵权/违法违规/事实不符,请联系编程学习网邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!

相关文章

  1. Netty简介

    Netty 是基于 Java NIO 的异步事件驱动的网络应用框架,使用 Netty 可以快速开发网络应用,Netty 提供了高层次的抽象来简化 TCP 和 UDP 服务器的编程,但是你仍然可以使用底层的 API。 Netty 的内部实现是很复杂的,但是 Netty 提供了…...

    2024/5/5 21:39:21
  2. 批量向PDF文件添加中文水印...

    可以通过设置批量PDF文件所在的路径及需要添加的水印名称可以实现批量添加PDF水印的效果。 实现思路是这样的,通过在批量PDF文件路径下面生成一个带有水印的PDF模板。最后,将批量文件的每个PDF页面和水印模板进行合并完成批量添加水印的效果。 【阅读全…...

    2024/4/13 12:20:11
  3. 第四次网页前端培训

    1.视频讲解:【优极限】 HTMLCSSJavaScriptjQuery前端必学教程,小白教学,前端基础全套完成版_哔哩哔哩_bilibili 1,css常用属性: 背景: background-color 属性定义了元素的背景颜色 实例: h…...

    2024/4/13 12:19:41
  4. python中yield,greenlet,gevent实现协程

    一.什么是协程: 协程是python中另外一种实现多任务的方式,只不过比线程更小,占用的执行资源(理解为需要的资源)也更少。为啥说他说一个执行单元?因为他自带cpu上下文,这样,在合适的额…...

    2024/5/6 2:29:01
  5. 小程序云开发入门——关于云函数那些事(2)

    上传视频到云存储 wx.chooseVideo(Object object) 1.选择要上传的视频 //上传视频,第一步选择要上传的视频chooseVideo(){wx.chooseVideo({camera:back,//后置或前置摄像头compressed: true,maxDuration: 60,//视频最长的秒数sourceType: [album,camera],//从相册选…...

    2024/5/5 21:19:25
  6. 死磕ES-第一章

    一句话介绍 Elasticsearch是实时的分布式搜索分析引擎,内部使用 Lucene 做索引与搜索。 主要功能 分布式搜索引擎 大数据近实时分析引擎 产品特性 高性能易用易扩展 Lucene 是基于Java语言开发的类库具有高性能、易扩展的特点具有局限性 只能基于Java语言开…...

    2024/5/5 22:29:09
  7. 自动运镜项目

    ipad21 人【人像居中】功能效果 效果演示: https://9to5mac.com/2021/05/19/roundup-heres-how-the-2021-ipad-pro-center-stage-feature-really-works/ https://www.youtube.com/watch?vTzwtHRPGSkM 复现实现: 单帧具备的功能: 根据检测到…...

    2024/4/16 3:42:31
  8. 什么是ad hoc

    Ad hoc是一种多跳的、无中心的、自组织无线网络,又称为多跳网(MulTI-hop Network)、无基础设施网(Infrastructureless Network)或自组织网(Self-organizing Network)。整个网络没有固定的基础设…...

    2024/4/20 14:58:58
  9. IO面试题

    笔试面试题: 1 文件IO和标准IO的区别 文件IO是Linux系统调用(内核API),而标准IO是C语言库函数; 文件IO不带缓冲,标准IO带有缓冲 文件IO操作的是文件描述符,标准IO操作的是流FILE 文件IO和标…...

    2024/5/6 2:57:14
  10. Java小农养成记第二十九天

    day29 今日内容 数据库连接池Spring JDBC :JDBC Template 数据库连接池 概念:其实就是一个容器(集合),存放数据库连接的容器 当系统初始化好后,容器中会申请一些连接对象,当用户来访问数据库…...

    2024/5/5 19:13:10
  11. 官方还有这个控件?Android优雅实现小红点效果,so easy~

    作者:yechaoa 一、前言 通常情况下,我们在做小红点效果的时候,会有两种选择: 自定义BadgeView,然后设置给目标View。 xml写一个View,然后设置shape。 有的同学可能会想,能实现不就行了吗&am…...

    2024/4/20 10:23:29
  12. 密码学入门(4):公钥密码

    密码学入门(4):公钥密码 文章目录密码学入门(4):公钥密码密钥配送问题解决密钥配送问题的方法公钥密码RSA生成密钥对对RSA的攻击中间人攻击其他公钥密码混合密码系统密码技术的组合参考公钥密码用公钥加密&…...

    2024/4/13 12:19:41
  13. Anaconda+PyCharm+Python下载安装

    Anaconda下载安装 link:清华镜像 下载自己电脑操作系统对应的版本即可,如:我的电脑Windows 64位 下载的是Anaconda3-2020.02-Windows-x86_64.exe,之所以没下载最新版本的,是因为我常用的是python3.7 安装时注意 记住全都勾选&a…...

    2024/4/13 12:19:56
  14. 【 爬虫解决了什么问题】

    爬虫解决了什么问题? 爬虫解决获取数据的问题。 互联网上有哪些数据值得爬取? 公司内部数据 业务数据,公司使用BI(Business Intelligence)、CRM系统、ERP系统、邮件系统等产生的数据; 财务数据,…...

    2024/4/19 5:05:48
  15. 深入源码分析Android插件化原理

    前言 插件化技术最初源于免安装运行 apk 的想法,这个免安装的 apk 就可以理解为插件,而支持插件的 app 我们一般叫宿主。宿主可以在运行时加载和运行插件,这样便可以将 app 中一些不常用的功能模块做成插件,一方面减小了安装包的…...

    2024/4/28 1:09:56
  16. 持续集成及jenkins介绍

    目录一,软件开发生命周期1.2 软件开发瀑布模型1.3 软件的敏捷开发1.4 什么是持续集成1.5 持续集成的组成要素1.6持续集成的好处二,Jenkins介绍2.2 jenkins的特征:2.3 Jenkins安装和持续集成环境配置三,服务器列表3.2 Gitlab代码托…...

    2024/4/17 21:47:34
  17. 数据结构与算法之 十大排序算法

    十大排序算法 排序算法的性质 OI Wiki:排序简介 稳定性:相等的元素经过排序之后相对顺序**是否发生了改变。时间复杂度:时间复杂度分为最优时间复杂度、平均时间复杂度和最坏时间复杂度。 选择排序 OI Wiki:选择排序 算法思路…...

    2024/4/13 12:19:46
  18. Flowable源码注释(二十四)引擎部署器和BPMN部署器(上)

    Flowable源码地址:https://github.com/flowable/flowable-engine Flowable-6.7.2 源码注释地址:https://github.com/solojin/flowable-6.7.2-annotated 包路径 org.flowable.common.engine.impl EngineDeployer 引擎部署器 /*** 引擎部署器&#xff…...

    2024/4/7 21:57:07
  19. 个人网站搭建,个人网站需要什么软件

    好的网页设计软件通过编码平台或简单的拖放就可以构架一个简单的个人网站。过去的网站建设需要用HTMLCSS和JS来制作。然而随着建站技术越来越成熟,拖放式网页制作工具越来越普遍,任何人都可以轻而易举地搭建自己的个人网站。 在本文中,我们将…...

    2024/4/13 12:19:41
  20. 利用GPU训练

    今晚开车去看灯啦。很开心 言归正传,有两种方法可以用GPU训练 方法一: 在 网络模型 损失器 数据(输入,标注) 上加上 if torch.cuda.is_available():name name.cuda()方法二: 先加上这行代码 device t…...

    2024/4/19 23:06:22

最新文章

  1. C++程序设计:new和malloc的区别

    new和malloc的区别 1.用法和语法2.类型安全性3.初始化4.分配数组5.异常处理示例代码 1.用法和语法 new 是 C 中的运算符,而 malloc 是 C 语言中的函数。new 用于动态分配单个对象或数组,并且在分配内存后调用对象的构造函数进行初始化。malloc 用于动态分…...

    2024/5/6 4:18:06
  2. 梯度消失和梯度爆炸的一些处理方法

    在这里是记录一下梯度消失或梯度爆炸的一些处理技巧。全当学习总结了如有错误还请留言,在此感激不尽。 权重和梯度的更新公式如下: w w − η ⋅ ∇ w w w - \eta \cdot \nabla w ww−η⋅∇w 个人通俗的理解梯度消失就是网络模型在反向求导的时候出…...

    2024/3/20 10:50:27
  3. 北航2023年考研机试题

    【问题描述】一共6个手机基站,具有记录手机连接基站的能力,6个手机基站分别为ABCDEF,他们具有自己的覆盖范围且任何两个基站的覆盖范围不想交,基站保存的手机登陆日志包括手机号(11位,用字符串保存&#xf…...

    2024/5/5 8:38:20
  4. k8s_入门_kubelet安装

    安装 在大致了解了一些k8s的基本概念之后,我们实际部署一个k8s集群,做进一步的了解 1. 裸机安装 采用三台机器,一台机器为Master(控制面板组件)两台机器为Node(工作节点) 机器的准备有两种方式…...

    2024/5/4 14:33:56
  5. 【外汇早评】美通胀数据走低,美元调整

    原标题:【外汇早评】美通胀数据走低,美元调整昨日美国方面公布了新一期的核心PCE物价指数数据,同比增长1.6%,低于前值和预期值的1.7%,距离美联储的通胀目标2%继续走低,通胀压力较低,且此前美国一季度GDP初值中的消费部分下滑明显,因此市场对美联储后续更可能降息的政策…...

    2024/5/4 23:54:56
  6. 【原油贵金属周评】原油多头拥挤,价格调整

    原标题:【原油贵金属周评】原油多头拥挤,价格调整本周国际劳动节,我们喜迎四天假期,但是整个金融市场确实流动性充沛,大事频发,各个商品波动剧烈。美国方面,在本周四凌晨公布5月份的利率决议和新闻发布会,维持联邦基金利率在2.25%-2.50%不变,符合市场预期。同时美联储…...

    2024/5/4 23:54:56
  7. 【外汇周评】靓丽非农不及疲软通胀影响

    原标题:【外汇周评】靓丽非农不及疲软通胀影响在刚结束的周五,美国方面公布了新一期的非农就业数据,大幅好于前值和预期,新增就业重新回到20万以上。具体数据: 美国4月非农就业人口变动 26.3万人,预期 19万人,前值 19.6万人。 美国4月失业率 3.6%,预期 3.8%,前值 3…...

    2024/5/4 23:54:56
  8. 【原油贵金属早评】库存继续增加,油价收跌

    原标题:【原油贵金属早评】库存继续增加,油价收跌周三清晨公布美国当周API原油库存数据,上周原油库存增加281万桶至4.692亿桶,增幅超过预期的74.4万桶。且有消息人士称,沙特阿美据悉将于6月向亚洲炼油厂额外出售更多原油,印度炼油商预计将每日获得至多20万桶的额外原油供…...

    2024/5/4 23:55:17
  9. 【外汇早评】日本央行会议纪要不改日元强势

    原标题:【外汇早评】日本央行会议纪要不改日元强势近两日日元大幅走强与近期市场风险情绪上升,避险资金回流日元有关,也与前一段时间的美日贸易谈判给日本缓冲期,日本方面对汇率问题也避免继续贬值有关。虽然今日早间日本央行公布的利率会议纪要仍然是支持宽松政策,但这符…...

    2024/5/4 23:54:56
  10. 【原油贵金属早评】欧佩克稳定市场,填补伊朗问题的影响

    原标题:【原油贵金属早评】欧佩克稳定市场,填补伊朗问题的影响近日伊朗局势升温,导致市场担忧影响原油供给,油价试图反弹。此时OPEC表态稳定市场。据消息人士透露,沙特6月石油出口料将低于700万桶/日,沙特已经收到石油消费国提出的6月份扩大出口的“适度要求”,沙特将满…...

    2024/5/4 23:55:05
  11. 【外汇早评】美欲与伊朗重谈协议

    原标题:【外汇早评】美欲与伊朗重谈协议美国对伊朗的制裁遭到伊朗的抗议,昨日伊朗方面提出将部分退出伊核协议。而此行为又遭到欧洲方面对伊朗的谴责和警告,伊朗外长昨日回应称,欧洲国家履行它们的义务,伊核协议就能保证存续。据传闻伊朗的导弹已经对准了以色列和美国的航…...

    2024/5/4 23:54:56
  12. 【原油贵金属早评】波动率飙升,市场情绪动荡

    原标题:【原油贵金属早评】波动率飙升,市场情绪动荡因中美贸易谈判不安情绪影响,金融市场各资产品种出现明显的波动。随着美国与中方开启第十一轮谈判之际,美国按照既定计划向中国2000亿商品征收25%的关税,市场情绪有所平复,已经开始接受这一事实。虽然波动率-恐慌指数VI…...

    2024/5/4 23:55:16
  13. 【原油贵金属周评】伊朗局势升温,黄金多头跃跃欲试

    原标题:【原油贵金属周评】伊朗局势升温,黄金多头跃跃欲试美国和伊朗的局势继续升温,市场风险情绪上升,避险黄金有向上突破阻力的迹象。原油方面稍显平稳,近期美国和OPEC加大供给及市场需求回落的影响,伊朗局势并未推升油价走强。近期中美贸易谈判摩擦再度升级,美国对中…...

    2024/5/4 23:54:56
  14. 【原油贵金属早评】市场情绪继续恶化,黄金上破

    原标题:【原油贵金属早评】市场情绪继续恶化,黄金上破周初中国针对于美国加征关税的进行的反制措施引发市场情绪的大幅波动,人民币汇率出现大幅的贬值动能,金融市场受到非常明显的冲击。尤其是波动率起来之后,对于股市的表现尤其不安。隔夜美国股市出现明显的下行走势,这…...

    2024/5/6 1:40:42
  15. 【外汇早评】美伊僵持,风险情绪继续升温

    原标题:【外汇早评】美伊僵持,风险情绪继续升温昨日沙特两艘油轮再次发生爆炸事件,导致波斯湾局势进一步恶化,市场担忧美伊可能会出现摩擦生火,避险品种获得支撑,黄金和日元大幅走强。美指受中美贸易问题影响而在低位震荡。继5月12日,四艘商船在阿联酋领海附近的阿曼湾、…...

    2024/5/4 23:54:56
  16. 【原油贵金属早评】贸易冲突导致需求低迷,油价弱势

    原标题:【原油贵金属早评】贸易冲突导致需求低迷,油价弱势近日虽然伊朗局势升温,中东地区几起油船被袭击事件影响,但油价并未走高,而是出于调整结构中。由于市场预期局势失控的可能性较低,而中美贸易问题导致的全球经济衰退风险更大,需求会持续低迷,因此油价调整压力较…...

    2024/5/4 23:55:17
  17. 氧生福地 玩美北湖(上)——为时光守候两千年

    原标题:氧生福地 玩美北湖(上)——为时光守候两千年一次说走就走的旅行,只有一张高铁票的距离~ 所以,湖南郴州,我来了~ 从广州南站出发,一个半小时就到达郴州西站了。在动车上,同时改票的南风兄和我居然被分到了一个车厢,所以一路非常愉快地聊了过来。 挺好,最起…...

    2024/5/4 23:55:06
  18. 氧生福地 玩美北湖(中)——永春梯田里的美与鲜

    原标题:氧生福地 玩美北湖(中)——永春梯田里的美与鲜一觉醒来,因为大家太爱“美”照,在柳毅山庄去寻找龙女而错过了早餐时间。近十点,向导坏坏还是带着饥肠辘辘的我们去吃郴州最富有盛名的“鱼头粉”。说这是“十二分推荐”,到郴州必吃的美食之一。 哇塞!那个味美香甜…...

    2024/5/4 23:54:56
  19. 氧生福地 玩美北湖(下)——奔跑吧骚年!

    原标题:氧生福地 玩美北湖(下)——奔跑吧骚年!让我们红尘做伴 活得潇潇洒洒 策马奔腾共享人世繁华 对酒当歌唱出心中喜悦 轰轰烈烈把握青春年华 让我们红尘做伴 活得潇潇洒洒 策马奔腾共享人世繁华 对酒当歌唱出心中喜悦 轰轰烈烈把握青春年华 啊……啊……啊 两…...

    2024/5/4 23:55:06
  20. 扒开伪装医用面膜,翻六倍价格宰客,小姐姐注意了!

    原标题:扒开伪装医用面膜,翻六倍价格宰客,小姐姐注意了!扒开伪装医用面膜,翻六倍价格宰客!当行业里的某一品项火爆了,就会有很多商家蹭热度,装逼忽悠,最近火爆朋友圈的医用面膜,被沾上了污点,到底怎么回事呢? “比普通面膜安全、效果好!痘痘、痘印、敏感肌都能用…...

    2024/5/5 8:13:33
  21. 「发现」铁皮石斛仙草之神奇功效用于医用面膜

    原标题:「发现」铁皮石斛仙草之神奇功效用于医用面膜丽彦妆铁皮石斛医用面膜|石斛多糖无菌修护补水贴19大优势: 1、铁皮石斛:自唐宋以来,一直被列为皇室贡品,铁皮石斛生于海拔1600米的悬崖峭壁之上,繁殖力差,产量极低,所以古代仅供皇室、贵族享用 2、铁皮石斛自古民间…...

    2024/5/4 23:55:16
  22. 丽彦妆\医用面膜\冷敷贴轻奢医学护肤引导者

    原标题:丽彦妆\医用面膜\冷敷贴轻奢医学护肤引导者【公司简介】 广州华彬企业隶属香港华彬集团有限公司,专注美业21年,其旗下品牌: 「圣茵美」私密荷尔蒙抗衰,产后修复 「圣仪轩」私密荷尔蒙抗衰,产后修复 「花茵莳」私密荷尔蒙抗衰,产后修复 「丽彦妆」专注医学护…...

    2024/5/4 23:54:58
  23. 广州械字号面膜生产厂家OEM/ODM4项须知!

    原标题:广州械字号面膜生产厂家OEM/ODM4项须知!广州械字号面膜生产厂家OEM/ODM流程及注意事项解读: 械字号医用面膜,其实在我国并没有严格的定义,通常我们说的医美面膜指的应该是一种「医用敷料」,也就是说,医用面膜其实算作「医疗器械」的一种,又称「医用冷敷贴」。 …...

    2024/5/4 23:55:01
  24. 械字号医用眼膜缓解用眼过度到底有无作用?

    原标题:械字号医用眼膜缓解用眼过度到底有无作用?医用眼膜/械字号眼膜/医用冷敷眼贴 凝胶层为亲水高分子材料,含70%以上的水分。体表皮肤温度传导到本产品的凝胶层,热量被凝胶内水分子吸收,通过水分的蒸发带走大量的热量,可迅速地降低体表皮肤局部温度,减轻局部皮肤的灼…...

    2024/5/4 23:54:56
  25. 配置失败还原请勿关闭计算机,电脑开机屏幕上面显示,配置失败还原更改 请勿关闭计算机 开不了机 这个问题怎么办...

    解析如下:1、长按电脑电源键直至关机,然后再按一次电源健重启电脑,按F8健进入安全模式2、安全模式下进入Windows系统桌面后,按住“winR”打开运行窗口,输入“services.msc”打开服务设置3、在服务界面,选中…...

    2022/11/19 21:17:18
  26. 错误使用 reshape要执行 RESHAPE,请勿更改元素数目。

    %读入6幅图像(每一幅图像的大小是564*564) f1 imread(WashingtonDC_Band1_564.tif); subplot(3,2,1),imshow(f1); f2 imread(WashingtonDC_Band2_564.tif); subplot(3,2,2),imshow(f2); f3 imread(WashingtonDC_Band3_564.tif); subplot(3,2,3),imsho…...

    2022/11/19 21:17:16
  27. 配置 已完成 请勿关闭计算机,win7系统关机提示“配置Windows Update已完成30%请勿关闭计算机...

    win7系统关机提示“配置Windows Update已完成30%请勿关闭计算机”问题的解决方法在win7系统关机时如果有升级系统的或者其他需要会直接进入一个 等待界面,在等待界面中我们需要等待操作结束才能关机,虽然这比较麻烦,但是对系统进行配置和升级…...

    2022/11/19 21:17:15
  28. 台式电脑显示配置100%请勿关闭计算机,“准备配置windows 请勿关闭计算机”的解决方法...

    有不少用户在重装Win7系统或更新系统后会遇到“准备配置windows,请勿关闭计算机”的提示,要过很久才能进入系统,有的用户甚至几个小时也无法进入,下面就教大家这个问题的解决方法。第一种方法:我们首先在左下角的“开始…...

    2022/11/19 21:17:14
  29. win7 正在配置 请勿关闭计算机,怎么办Win7开机显示正在配置Windows Update请勿关机...

    置信有很多用户都跟小编一样遇到过这样的问题,电脑时发现开机屏幕显现“正在配置Windows Update,请勿关机”(如下图所示),而且还需求等大约5分钟才干进入系统。这是怎样回事呢?一切都是正常操作的,为什么开时机呈现“正…...

    2022/11/19 21:17:13
  30. 准备配置windows 请勿关闭计算机 蓝屏,Win7开机总是出现提示“配置Windows请勿关机”...

    Win7系统开机启动时总是出现“配置Windows请勿关机”的提示,没过几秒后电脑自动重启,每次开机都这样无法进入系统,此时碰到这种现象的用户就可以使用以下5种方法解决问题。方法一:开机按下F8,在出现的Windows高级启动选…...

    2022/11/19 21:17:12
  31. 准备windows请勿关闭计算机要多久,windows10系统提示正在准备windows请勿关闭计算机怎么办...

    有不少windows10系统用户反映说碰到这样一个情况,就是电脑提示正在准备windows请勿关闭计算机,碰到这样的问题该怎么解决呢,现在小编就给大家分享一下windows10系统提示正在准备windows请勿关闭计算机的具体第一种方法:1、2、依次…...

    2022/11/19 21:17:11
  32. 配置 已完成 请勿关闭计算机,win7系统关机提示“配置Windows Update已完成30%请勿关闭计算机”的解决方法...

    今天和大家分享一下win7系统重装了Win7旗舰版系统后,每次关机的时候桌面上都会显示一个“配置Windows Update的界面,提示请勿关闭计算机”,每次停留好几分钟才能正常关机,导致什么情况引起的呢?出现配置Windows Update…...

    2022/11/19 21:17:10
  33. 电脑桌面一直是清理请关闭计算机,windows7一直卡在清理 请勿关闭计算机-win7清理请勿关机,win7配置更新35%不动...

    只能是等着,别无他法。说是卡着如果你看硬盘灯应该在读写。如果从 Win 10 无法正常回滚,只能是考虑备份数据后重装系统了。解决来方案一:管理员运行cmd:net stop WuAuServcd %windir%ren SoftwareDistribution SDoldnet start WuA…...

    2022/11/19 21:17:09
  34. 计算机配置更新不起,电脑提示“配置Windows Update请勿关闭计算机”怎么办?

    原标题:电脑提示“配置Windows Update请勿关闭计算机”怎么办?win7系统中在开机与关闭的时候总是显示“配置windows update请勿关闭计算机”相信有不少朋友都曾遇到过一次两次还能忍但经常遇到就叫人感到心烦了遇到这种问题怎么办呢?一般的方…...

    2022/11/19 21:17:08
  35. 计算机正在配置无法关机,关机提示 windows7 正在配置windows 请勿关闭计算机 ,然后等了一晚上也没有关掉。现在电脑无法正常关机...

    关机提示 windows7 正在配置windows 请勿关闭计算机 ,然后等了一晚上也没有关掉。现在电脑无法正常关机以下文字资料是由(历史新知网www.lishixinzhi.com)小编为大家搜集整理后发布的内容,让我们赶快一起来看一下吧!关机提示 windows7 正在配…...

    2022/11/19 21:17:05
  36. 钉钉提示请勿通过开发者调试模式_钉钉请勿通过开发者调试模式是真的吗好不好用...

    钉钉请勿通过开发者调试模式是真的吗好不好用 更新时间:2020-04-20 22:24:19 浏览次数:729次 区域: 南阳 > 卧龙 列举网提醒您:为保障您的权益,请不要提前支付任何费用! 虚拟位置外设器!!轨迹模拟&虚拟位置外设神器 专业用于:钉钉,外勤365,红圈通,企业微信和…...

    2022/11/19 21:17:05
  37. 配置失败还原请勿关闭计算机怎么办,win7系统出现“配置windows update失败 还原更改 请勿关闭计算机”,长时间没反应,无法进入系统的解决方案...

    前几天班里有位学生电脑(windows 7系统)出问题了,具体表现是开机时一直停留在“配置windows update失败 还原更改 请勿关闭计算机”这个界面,长时间没反应,无法进入系统。这个问题原来帮其他同学也解决过,网上搜了不少资料&#x…...

    2022/11/19 21:17:04
  38. 一个电脑无法关闭计算机你应该怎么办,电脑显示“清理请勿关闭计算机”怎么办?...

    本文为你提供了3个有效解决电脑显示“清理请勿关闭计算机”问题的方法,并在最后教给你1种保护系统安全的好方法,一起来看看!电脑出现“清理请勿关闭计算机”在Windows 7(SP1)和Windows Server 2008 R2 SP1中,添加了1个新功能在“磁…...

    2022/11/19 21:17:03
  39. 请勿关闭计算机还原更改要多久,电脑显示:配置windows更新失败,正在还原更改,请勿关闭计算机怎么办...

    许多用户在长期不使用电脑的时候,开启电脑发现电脑显示:配置windows更新失败,正在还原更改,请勿关闭计算机。。.这要怎么办呢?下面小编就带着大家一起看看吧!如果能够正常进入系统,建议您暂时移…...

    2022/11/19 21:17:02
  40. 还原更改请勿关闭计算机 要多久,配置windows update失败 还原更改 请勿关闭计算机,电脑开机后一直显示以...

    配置windows update失败 还原更改 请勿关闭计算机,电脑开机后一直显示以以下文字资料是由(历史新知网www.lishixinzhi.com)小编为大家搜集整理后发布的内容,让我们赶快一起来看一下吧!配置windows update失败 还原更改 请勿关闭计算机&#x…...

    2022/11/19 21:17:01
  41. 电脑配置中请勿关闭计算机怎么办,准备配置windows请勿关闭计算机一直显示怎么办【图解】...

    不知道大家有没有遇到过这样的一个问题,就是我们的win7系统在关机的时候,总是喜欢显示“准备配置windows,请勿关机”这样的一个页面,没有什么大碍,但是如果一直等着的话就要两个小时甚至更久都关不了机,非常…...

    2022/11/19 21:17:00
  42. 正在准备配置请勿关闭计算机,正在准备配置windows请勿关闭计算机时间长了解决教程...

    当电脑出现正在准备配置windows请勿关闭计算机时,一般是您正对windows进行升级,但是这个要是长时间没有反应,我们不能再傻等下去了。可能是电脑出了别的问题了,来看看教程的说法。正在准备配置windows请勿关闭计算机时间长了方法一…...

    2022/11/19 21:16:59
  43. 配置失败还原请勿关闭计算机,配置Windows Update失败,还原更改请勿关闭计算机...

    我们使用电脑的过程中有时会遇到这种情况,当我们打开电脑之后,发现一直停留在一个界面:“配置Windows Update失败,还原更改请勿关闭计算机”,等了许久还是无法进入系统。如果我们遇到此类问题应该如何解决呢&#xff0…...

    2022/11/19 21:16:58
  44. 如何在iPhone上关闭“请勿打扰”

    Apple’s “Do Not Disturb While Driving” is a potentially lifesaving iPhone feature, but it doesn’t always turn on automatically at the appropriate time. For example, you might be a passenger in a moving car, but your iPhone may think you’re the one dri…...

    2022/11/19 21:16:57