Title: 一文归纳Python特征生成方法(全) · Issue #11 · aialgorithm/Blog · GitHub
Open Graph Title: 一文归纳Python特征生成方法(全) · Issue #11 · aialgorithm/Blog
X Title: 一文归纳Python特征生成方法(全) · Issue #11 · aialgorithm/Blog
Description: 业内常说数据决定了模型效果上限,而机器学习算法是通过数据特征做出预测的,好的特征可以显著地提升模型效果。这意味着通过特征生成(即从数据设计加工出模型可用特征),是特征工程相当关键的一步。本文从特征生成作用、特征生成的方法(人工设计、自动化特征生成)展开阐述并附上代码。 创造新的特征是一件十分困难的事情,需要丰富的专业知识和大量的时间。机器学习应用的本质基本上就是特征工程。 ——Andrew Ng 1 特征生成的作用 特征生成是特征提取中的重要一步,作用在于: 增加特征的...
Open Graph Description: 业内常说数据决定了模型效果上限,而机器学习算法是通过数据特征做出预测的,好的特征可以显著地提升模型效果。这意味着通过特征生成(即从数据设计加工出模型可用特征),是特征工程相当关键的一步。本文从特征生成作用、特征生成的方法(人工设计、自动化特征生成)展开阐述并附上代码。 创造新的特征是一件十分困难的事情,需要丰富的专业知识和大量的时间。机器学习应用的本质基本上就是特征工程。 ——Andrew ...
X Description: 业内常说数据决定了模型效果上限,而机器学习算法是通过数据特征做出预测的,好的特征可以显著地提升模型效果。这意味着通过特征生成(即从数据设计加工出模型可用特征),是特征工程相当关键的一步。本文从特征生成作用、特征生成的方法(人工设计、自动化特征生成)展开阐述并附上代码。 创造新的特征是一件十分困难的事情,需要丰富的专业知识和大量的时间。机器学习应用的本质基本上就是特征工程。 ——Andrew ...
Opengraph URL: https://github.com/aialgorithm/Blog/issues/11
X: @github
Domain: github.com
{"@context":"https://schema.org","@type":"DiscussionForumPosting","headline":"一文归纳Python特征生成方法(全)","articleBody":"业内常说数据决定了模型效果上限,而机器学习算法是通过数据特征做出预测的,好的特征可以显著地提升模型效果。这意味着通过特征生成(即从数据设计加工出模型可用特征),是特征工程相当关键的一步。本文从特征生成作用、特征生成的方法(人工设计、自动化特征生成)展开阐述并附上代码。\r\n\r\n\u003e创造新的特征是一件十分困难的事情,需要丰富的专业知识和大量的时间。机器学习应用的本质基本上就是特征工程。\r\n——Andrew Ng\r\n\r\n\r\n\r\n# 1 特征生成的作用\r\n\r\n\r\n特征生成是特征提取中的重要一步,作用在于:\r\n- 增加特征的表达能力,提升模型效果;(如体重除以身高就是表达健康情况的重要特征,而单纯看身高或体重对健康情况表达就有限。)\r\n- 可以融入业务上的理解设计特征,增加模型的可解释性;\r\n\r\n## 2 数据情况分析\r\n\r\n本文示例的数据集是客户的资金变动情况,如下数据字典:\r\n```\r\ncust_no:客户编号;I1 :性别;I2:年龄 ;E1:开户日期; \r\nB6 :近期转账日期;C1 (后缀_fir表示上个月):存款;C2:存款产品数; \r\nX1:理财存款; X2:结构性存款; label:资金情况上升下降情况。\r\n```\r\n\r\n这里安利一个超实用Python库,可以一键数据分析(数据概况、缺失、相关性、异常值等等),方便结合数据分析报告做特征生成。\r\n\r\n\r\n\r\n```\r\n# 一键数据分析\r\nimport pandas_profiling\r\n\r\npandas_profiling.ProfileReport(df)\r\n```\r\n\r\n\r\n\r\n## 3 特征生成的方法\r\n特征生成方法可以分为两类:聚合方式、转换方式。\r\n\r\n\r\n\r\n\r\n### 3.1 聚合方式\r\n\r\n\r\n**聚合方式**是指对存在一对多的字段,将其对应多条记录分组聚合后统计平均值、计数、最大值等数据特征。\r\n如以上述数据集,同一cust_no对应多条记录,通过对cust_no(客户编号)做分组聚合,统计C1字段个数、唯一数、平均值、中位数、标准差、总和、最大、最小值,最终得到按每个cust_no统计的C1平均值、最大值等特征。\r\n```\r\n# 以cust_no做聚合,C1字段统计个数、唯一数、平均值、中位数、标准差、总和、最大、最小值\r\ndf.groupby('cust_no').C1.agg(['count','nunique','mean','median','std','sum','max','min'])\r\n```\r\n\r\n此外还可以pandas自定义聚合函数生成特征,比如加工聚合元素的平方和:\r\n```\r\n# 自定义分组聚合统计函数\r\ndef x2_sum(group):\r\n return sum(group**2)\r\n\r\ndf.groupby('cust_no').C1.apply(x2_sum) \r\n```\r\n\r\n\r\n### 3.2 转换方式\r\n**转换方式**是指对字段间做加减乘除等运算生成数据特征的过程,对不同字段类型有不同转换方式。\r\n#### 3.2.1 数值类型\r\n- 加减乘除\r\n多个字段做运算生成新的特征,这通常需要结合业务层面的理解以及数据分布的情况,以生成较优的特征集。\r\n\r\n\r\n```\r\nimport numpy as np\r\n\r\n# 前后两个月资金和\r\ndf['C1+C1_fir'] = df['C1']+df['C1_fir']\r\n# 前后两个月资金差异\r\ndf['C1-C1_fir'] = df['C1']-df['C1_fir']\r\n# 产品数*资金\r\ndf['C1*C2'] = df['C1']*df['C2']\r\n# 前后两个月资金变化率\r\ndf['C1/C1_fir'] = df['C1']/df['C1_fir'] - 1\r\ndf.head()\r\n```\r\n\r\n\r\n- 多个列统计\r\n直接用聚合函数统计多列的方差、均值等\r\n\r\n\r\n```\r\nimport numpy as np\r\n\r\ndf['C1_sum'] = np.sum(df[['C1_fir','C1']], axis = 1)\r\ndf['C1_var'] = np.var(df[['C1_fir','C1']], axis = 1)\r\ndf['C1_max'] = np.max(df[['C1_fir','C1']], axis = 1)\r\ndf['C1_min'] = np.min(df[['C1_fir','C1']], axis = 1)\r\ndf['C1-C1_fir_abs'] = np.abs(df['C1-C1_fir'])\r\ndf.head()\r\n```\r\n\r\n- 排名编码特征\r\n按特征值对全体样本进行排序,以排序序号作为特征值。这种特征对异常点不敏感,也不容易导致特征值冲突。\r\n\r\n```\r\n# 排序特征\r\n\r\ndf['C1_rank'] = df['C1'].rank(ascending=0, method='dense')\r\ndf.head()\r\n```\r\n\r\n\r\n\r\n#### 3.2.2 字符类型\r\n- 截取\r\n当字符类型的值过多,通常可对字符类型变量做截取,以减少模型过拟合。如具体的家庭住址,可以截取字符串到城市级的粒度。\r\n\r\n- 字符长度\r\n统计字符串长度。如转账场景中,转账留言的字数某些程度可以刻画这笔转账的类型。\r\n\r\n- 频次\r\n通过统计字符出现频次。如欺诈场景中地址出现次数越多,越有可能是团伙欺诈。\r\n\r\n```\r\n# 字符特征\r\n# 由于没有合适的例子,这边只是用代码实现逻辑,加工的字段并无含义。\r\n\r\n#截取第一位字符串\r\ndf['I1_0'] = df['I1'].map(lambda x:str(x)[:1])\r\n# 字符长度\r\ndf['I1_len'] = df['I1'].apply(lambda x:len(str(x)))\r\n\r\ndisplay(df.head())\r\n# 字符串频次\r\ndf['I1'].value_counts()\r\n```\r\n\r\n#### 3.2.3 日期类型\r\n常用的有计算日期间隔、周几、几点等等。\r\n\r\n\r\n```\r\n# 日期类型\r\ndf['E1_B6_interval'] = (df.E1.astype('datetime64[ns]') - df.B6.astype('datetime64[ns]')).map(lambda x:x.days)\r\ndf['E1_is_month_end'] = pd.to_datetime(df.E1).map(lambda x :x.is_month_end)\r\ndf['E1_dayofweek'] = df.E1.astype('datetime64[ns]').dt.dayofweek\r\ndf['B6_hour'] = df.B6.astype('datetime64[ns]').dt.hour\r\ndf.head()\r\n```\r\n\r\n## 4 自动化特征生成\r\n\r\n传统的特征工程方法通过人工构建特征,这是一个繁琐、耗时且容易出错的过程。自动化特征工程是通过Fearturetools等工具,从一组相关数据表中自动生成有用的特征的过程。对比人工生成特征会更为高效,可重复性更高,能够更快地构建模型。\r\n### 4.1 FeatureTools上手\r\n\r\n\r\nFeaturetools是一个用于执行自动化特征工程的开源库,它有基本的3个概念:\r\n1)**Feature Primitives(特征基元)**:生成特征的常用方法,分为聚合(agg_primitives)、转换(trans_primitives)的方式。可通过如下代码列出featuretools的特征加工方法及简介。\r\n```\r\nimport featuretools as ft\r\n\r\nft.list_primitives()\r\n```\r\n\r\n\r\n2)**Entity(实体)** 可以被看作类似Pandas DataFrame, 多个实体的集合称为**Entityset**。实体间可以根据关联键添加关联关系**Relationship**。\r\n```\r\n# df1为原始的特征数据\r\ndf1 = df.drop('label',axis=1)\r\n\r\n# df2为客户清单(cust_no唯一值)\r\ndf2 = df[['cust_no']].drop_duplicates()\r\ndf2.head()\r\n\r\n# 定义数据集\r\nes = ft.EntitySet(id='dfs')\r\n\r\n# 增加一个df1数据框实体\r\nes.entity_from_dataframe(entity_id='df1', \r\n dataframe=df1,\r\n index='id',\r\n make_index=True)\r\n\r\n# 增加一个df2数据实体\r\nes.entity_from_dataframe(entity_id='df2', \r\n dataframe=df2,\r\n index='cust_no')\r\n\r\n\r\n# 添加实体间关系:通过 cust_no键关联 df_1 和 df 2实体\r\nrelation1 = ft.Relationship(es['df2']['cust_no'], es['df1']['cust_no'])\r\nes = es.add_relationship(relation1)\r\n\r\n```\r\n\r\n\r\n3)**dfs(深度特征合成)** : 是从多个数据集创建新特征的过程,可以通过设置搜索的最大深度(max_depth)来控制所特征生成的复杂性\r\n\r\n```\r\n## 运行DFS特征衍生\r\nfeatures_matrix,feature_names = ft.dfs(entityset=es,\r\n target_entity='df2',\r\n relationships = [relation1],\r\n trans_primitives=['divide_numeric','multiply_numeric','subtract_numeric'],\r\n agg_primitives=['sum'],\r\n max_depth=2,n_jobs=1,verbose=-1)\r\n```\r\n\r\n\r\n### 4.2 FeatureTools问题点\r\n4.2.1 内存溢出问题\r\nFearturetools是通过工程层面暴力生成所有特征的过程,当数据量大的时候,容易造成内存溢出。解决这个问题除了升级服务器内存,减少njobs,还有一个常用的是通过只选择重要的特征进行暴力衍生特征。\r\n\r\n4.2.2 特征维度爆炸\r\n当原始特征数量多,或max_depth、特征基元的种类设定较大,Fearturetools生成的特征数量巨大,容易维度爆炸。这是就需要考虑到特征选择、特征降维,常用的特征选择方法可以参考上一篇文章: [Python特征选择 ](https://mp.weixin.qq.com/s/YWqaza96XsNehkJCN-lWMg)\r\n\r\n---\r\n注:本文源码链接:Github。(公众号阅读原文可访问链接)\r\n \r\n","author":{"url":"https://github.com/aialgorithm","@type":"Person","name":"aialgorithm"},"datePublished":"2021-02-18T11:40:48.000Z","interactionStatistic":{"@type":"InteractionCounter","interactionType":"https://schema.org/CommentAction","userInteractionCount":0},"url":"https://github.com/11/Blog/issues/11"}
| route-pattern | /_view_fragments/issues/show/:user_id/:repository/:id/issue_layout(.:format) |
| route-controller | voltron_issues_fragments |
| route-action | issue_layout |
| fetch-nonce | v2:a0da8fb2-3d0b-a7d9-1a55-340ce293b4b1 |
| current-catalog-service-hash | 81bb79d38c15960b92d99bca9288a9108c7a47b18f2423d0f6438c5b7bcd2114 |
| request-id | 9CB2:70C3B:A71B13:E4693E:6969E93A |
| html-safe-nonce | a08709388b16c948066c75515365ec73e9badfd4f38acfe4207e527c9775f6f9 |
| visitor-payload | eyJyZWZlcnJlciI6IiIsInJlcXVlc3RfaWQiOiI5Q0IyOjcwQzNCOkE3MUIxMzpFNDY5M0U6Njk2OUU5M0EiLCJ2aXNpdG9yX2lkIjoiNTYyOTIxNDM3MTYyODA1MDc0NiIsInJlZ2lvbl9lZGdlIjoiaWFkIiwicmVnaW9uX3JlbmRlciI6ImlhZCJ9 |
| visitor-hmac | acd5c43ff55a8658bec582c115a286c825a0bd55d24f0ccbcff0251f119bb4c9 |
| hovercard-subject-tag | issue:811022073 |
| github-keyboard-shortcuts | repository,issues,copilot |
| google-site-verification | Apib7-x98H0j5cPqHWwSMm6dNU4GmODRoqxLiDzdx9I |
| octolytics-url | https://collector.github.com/github/collect |
| analytics-location | / |
| fb:app_id | 1401488693436528 |
| apple-itunes-app | app-id=1477376905, app-argument=https://github.com/_view_fragments/issues/show/aialgorithm/Blog/11/issue_layout |
| twitter:image | https://opengraph.githubassets.com/35a836f364740dfc52ae6cef2699ce962d9f62525ed70ba3cb1d07fa112b9893/aialgorithm/Blog/issues/11 |
| twitter:card | summary_large_image |
| og:image | https://opengraph.githubassets.com/35a836f364740dfc52ae6cef2699ce962d9f62525ed70ba3cb1d07fa112b9893/aialgorithm/Blog/issues/11 |
| og:image:alt | 业内常说数据决定了模型效果上限,而机器学习算法是通过数据特征做出预测的,好的特征可以显著地提升模型效果。这意味着通过特征生成(即从数据设计加工出模型可用特征),是特征工程相当关键的一步。本文从特征生成作用、特征生成的方法(人工设计、自动化特征生成)展开阐述并附上代码。 创造新的特征是一件十分困难的事情,需要丰富的专业知识和大量的时间。机器学习应用的本质基本上就是特征工程。 ——Andrew ... |
| og:image:width | 1200 |
| og:image:height | 600 |
| og:site_name | GitHub |
| og:type | object |
| og:author:username | aialgorithm |
| hostname | github.com |
| expected-hostname | github.com |
| None | 7b32f1c7c4549428ee399213e8345494fc55b5637195d3fc5f493657579235e8 |
| turbo-cache-control | no-preview |
| go-import | github.com/aialgorithm/Blog git https://github.com/aialgorithm/Blog.git |
| octolytics-dimension-user_id | 33707637 |
| octolytics-dimension-user_login | aialgorithm |
| octolytics-dimension-repository_id | 147093233 |
| octolytics-dimension-repository_nwo | aialgorithm/Blog |
| octolytics-dimension-repository_public | true |
| octolytics-dimension-repository_is_fork | false |
| octolytics-dimension-repository_network_root_id | 147093233 |
| octolytics-dimension-repository_network_root_nwo | aialgorithm/Blog |
| turbo-body-classes | logged-out env-production page-responsive |
| disable-turbo | false |
| browser-stats-url | https://api.github.com/_private/browser/stats |
| browser-errors-url | https://api.github.com/_private/browser/errors |
| release | bdde15ad1b403e23b08bbd89b53fbe6bdf688cad |
| ui-target | full |
| theme-color | #1e2327 |
| color-scheme | light dark |
Links:
Viewport: width=device-width