0

0

机器学习中对数转换预测值的逆变换方法

DDD

DDD

发布时间:2025-12-05 12:57:34

|

205人浏览过

|

来源于php中文网

原创

机器学习中对数转换预测值的逆变换方法

本文旨在详细阐述在机器学习模型中,如何将经过对数转换的预测结果还原为原始数据尺度。当数据因偏态分布等原因进行对数变换后,模型预测值将处于对数尺度。通过使用指数函数`np.exp()`,可以有效地将这些预测值逆变换回原始可解释的数值,并探讨在评估模型性能时,如何正确处理不同尺度下的误差计算。

在数据分析和机器学习领域,对数转换是一种常用的数据预处理技术,尤其适用于处理具有偏态分布的数值型特征,如收入、价格或销售额等。通过对数转换,可以使数据分布更接近正态分布,从而满足某些模型(如线性回归)对数据分布的假设,提高模型的稳定性和预测性能。

对数转换的必要性与实施

对数转换通常应用于目标变量(因变量)或某些独立变量(自变量),以解决数据偏斜、方差不齐或建立线性关系等问题。例如,当处理财务数据时,如商品价值或工资,这些数据往往呈现右偏分布,即大部分数值较小,少数数值非常大。对数转换可以有效压缩大数值的范围,拉伸小数值的范围,使数据分布更加均匀。

以下代码片段展示了如何对数据集中的value_eur和wage_eur两列进行自然对数转换:

import numpy as np
import pandas as pd
from sklearn.model_selection import train_test_split
from sklearn.metrics import mean_absolute_error
# 假设 dtd 是您的 DataFrame,dtk 是原始 DataFrame
# 为了演示,我们创建一个模拟数据
data = {
    'value_eur': np.random.exponential(scale=100000, size=1000) + 1, # 加1避免log(0)
    'wage_eur': np.random.exponential(scale=50000, size=1000) + 1,
    'feature1': np.random.rand(1000) * 100,
    'feature2': np.random.rand(1000) * 50
}
dtd = pd.DataFrame(data)
dtk = dtd.copy() # 模拟原始数据

# 对非零值进行对数转换
mask_value = dtd['value_eur'] > 0
dtd.loc[mask_value, 'value_eur'] = np.log(dtk.loc[mask_value, 'value_eur'])

mask_wage = dtd['wage_eur'] > 0
dtd.loc[mask_wage, 'wage_eur'] = np.log(dtk.loc[mask_wage, 'wage_eur'])

# 定义特征X和目标y
X = dtd.drop(['value_eur'], axis=1)
y = dtd['value_eur']

# 划分训练集和测试集
X_train, X_test, y_train, y_test = train_test_split(X, y, test_size=0.2, random_state=42)

# 假设 regressor 是一个已经训练好的模型,例如通过 GridSearchCV 获得的最佳估计器
# 这里使用一个简单的 RandomForestRegressor 作为示例
from sklearn.ensemble import RandomForestRegressor
regressor = RandomForestRegressor(random_state=42)
regressor.fit(X_train, y_train)

在上述代码中,value_eur和wage_eur被转换成了它们的自然对数值。这意味着模型在训练时,学习的是输入特征与目标变量的对数值之间的关系。

对数尺度预测值的挑战

当模型(如regressor)在对数转换后的目标变量y_train上进行训练并对X_test进行预测时,其输出regs也将是对数尺度的值。

# 进行预测
regs = regressor.predict(X_test)

# 打印对数尺度的预测值和真实值(y_test本身也是对数尺度)
results1 = pd.DataFrame({ ' grids predicted values': regs, '  true values': y_test})
print("对数尺度的预测结果示例:")
print(results1.head())

输出示例(注意这些值都比较小,因为它们是对数):

对数尺度的预测结果示例:
    grids predicted values   true values
10   11.080183    10.875322
285  10.744265    10.605335
689  11.137885    11.178312
603  11.066421    11.060205
808  11.233591    11.232517

这些对数尺度的预测值对于直接解释或与原始业务场景中的实际数值进行比较来说,并不直观。例如,一个对数值为15的预测,实际可能代表一个非常大的金额。因此,为了更好地理解模型的预测结果,需要将其还原到原始的数据尺度。

阿里云AI平台
阿里云AI平台

阿里云AI平台

下载

解决方案:使用指数函数进行逆变换

将对数转换后的值还原为原始尺度,需要使用对数函数的逆运算——指数函数。在Python的NumPy库中,np.exp()函数用于计算e的幂次方,即自然指数函数,它正是自然对数np.log()的逆运算。

要将模型的对数尺度预测值regs还原为原始尺度,只需对regs应用np.exp()函数即可:

# 将预测值从对数尺度还原到原始尺度
y_pred_original_scale = np.exp(regs)

# 将测试集真实值从对数尺度还原到原始尺度
y_test_original_scale = np.exp(y_test)

# 创建包含原始尺度预测值和真实值的DataFrame
results_original = pd.DataFrame({
    '预测值 (原始尺度)': y_pred_original_scale,
    '真实值 (原始尺度)': y_test_original_scale
})

print("\n原始尺度的预测结果示例:")
print(results_original.head())

输出示例(现在的值更大,更接近原始数据的数值范围):

原始尺度的预测结果示例:
     预测值 (原始尺度)   真实值 (原始尺度)
10  65538.214081  52870.970878
285 46376.425832  40348.435850
689 68715.753334  71578.473796
603 64003.552943  63595.340942
808 75592.578643  75510.672323

注意事项与最佳实践

  1. 误差指标的计算尺度一致性 在评估模型性能时,选择合适的误差计算尺度至关重要。

    • 在对数尺度下评估:如果想评估模型在对数空间中的表现,可以直接使用y_test和regs计算误差。例如,计算对数尺度的平均绝对误差(MAE):
      mae_log_scale = mean_absolute_error(y_test, regs)
      print(f"\n对数尺度的平均绝对误差 (MAE): {mae_log_scale:.4f}")
    • 在原始尺度下评估:如果希望误差指标反映原始数据尺度上的绝对差异,那么在计算误差之前,必须将y_test和regs都逆变换回原始尺度。
      mae_original_scale = mean_absolute_error(y_test_original_scale, y_pred_original_scale)
      print(f"原始尺度的平均绝对误差 (MAE): {mae_original_scale:.2f}")

      请注意,直接对对数尺度下的MAE进行np.exp()操作是不正确的,因为对数转换是非线性的,exp(MAE_log)不等于MAE_original。

  2. 数据预处理的一致性 确保在训练集、测试集以及任何新的预测数据上,对数转换和逆变换的逻辑保持一致。如果原始数据中存在零或负值,而对数函数只对正数有定义,那么在进行对数转换前需要进行适当的零值处理(例如加一个很小的常数,如np.log(x + 1))。在逆变换时,np.exp(x)的结果总是正数,这与原始数据中不可能出现负值的情况是吻合的。

  3. 模型选择与对数转换 某些模型(如广义线性模型中的泊松回归)可以直接处理计数数据,而不必进行对数转换。然而,对于大多数基于正态性假设的模型,对数转换仍然是处理偏态数据的有效手段。在进行对数转换后,模型实际上是在预测目标变量的相对变化,而不是绝对变化,这在某些业务场景下可能更有意义。

总结

对数转换是处理偏态数据和改善模型性能的强大工具。然而,为了使模型的预测结果具有实际意义和可解释性,将对数尺度的预测值逆变换回原始尺度是必不可少的步骤。通过简单地应用np.exp()函数,我们可以轻松实现这一目标。同时,在评估模型时,务必根据分析需求选择在对数尺度还是原始尺度下计算误差指标,并确保所有数据处理步骤的一致性,以得出准确且有意义的结论。

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

WorkBuddy
WorkBuddy

腾讯云推出的AI原生桌面智能体工作台

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
TypeScript类型系统进阶与大型前端项目实践
TypeScript类型系统进阶与大型前端项目实践

本专题围绕 TypeScript 在大型前端项目中的应用展开,深入讲解类型系统设计与工程化开发方法。内容包括泛型与高级类型、类型推断机制、声明文件编写、模块化结构设计以及代码规范管理。通过真实项目案例分析,帮助开发者构建类型安全、结构清晰、易维护的前端工程体系,提高团队协作效率与代码质量。

26

2026.03.13

Python异步编程与Asyncio高并发应用实践
Python异步编程与Asyncio高并发应用实践

本专题围绕 Python 异步编程模型展开,深入讲解 Asyncio 框架的核心原理与应用实践。内容包括事件循环机制、协程任务调度、异步 IO 处理以及并发任务管理策略。通过构建高并发网络请求与异步数据处理案例,帮助开发者掌握 Python 在高并发场景中的高效开发方法,并提升系统资源利用率与整体运行性能。

46

2026.03.12

C# ASP.NET Core微服务架构与API网关实践
C# ASP.NET Core微服务架构与API网关实践

本专题围绕 C# 在现代后端架构中的微服务实践展开,系统讲解基于 ASP.NET Core 构建可扩展服务体系的核心方法。内容涵盖服务拆分策略、RESTful API 设计、服务间通信、API 网关统一入口管理以及服务治理机制。通过真实项目案例,帮助开发者掌握构建高可用微服务系统的关键技术,提高系统的可扩展性与维护效率。

178

2026.03.11

Go高并发任务调度与Goroutine池化实践
Go高并发任务调度与Goroutine池化实践

本专题围绕 Go 语言在高并发任务处理场景中的实践展开,系统讲解 Goroutine 调度模型、Channel 通信机制以及并发控制策略。内容包括任务队列设计、Goroutine 池化管理、资源限制控制以及并发任务的性能优化方法。通过实际案例演示,帮助开发者构建稳定高效的 Go 并发任务处理系统,提高系统在高负载环境下的处理能力与稳定性。

51

2026.03.10

Kotlin Android模块化架构与组件化开发实践
Kotlin Android模块化架构与组件化开发实践

本专题围绕 Kotlin 在 Android 应用开发中的架构实践展开,重点讲解模块化设计与组件化开发的实现思路。内容包括项目模块拆分策略、公共组件封装、依赖管理优化、路由通信机制以及大型项目的工程化管理方法。通过真实项目案例分析,帮助开发者构建结构清晰、易扩展且维护成本低的 Android 应用架构体系,提升团队协作效率与项目迭代速度。

92

2026.03.09

JavaScript浏览器渲染机制与前端性能优化实践
JavaScript浏览器渲染机制与前端性能优化实践

本专题围绕 JavaScript 在浏览器中的执行与渲染机制展开,系统讲解 DOM 构建、CSSOM 解析、重排与重绘原理,以及关键渲染路径优化方法。内容涵盖事件循环机制、异步任务调度、资源加载优化、代码拆分与懒加载等性能优化策略。通过真实前端项目案例,帮助开发者理解浏览器底层工作原理,并掌握提升网页加载速度与交互体验的实用技巧。

102

2026.03.06

Rust内存安全机制与所有权模型深度实践
Rust内存安全机制与所有权模型深度实践

本专题围绕 Rust 语言核心特性展开,深入讲解所有权机制、借用规则、生命周期管理以及智能指针等关键概念。通过系统级开发案例,分析内存安全保障原理与零成本抽象优势,并结合并发场景讲解 Send 与 Sync 特性实现机制。帮助开发者真正理解 Rust 的设计哲学,掌握在高性能与安全性并重场景中的工程实践能力。

227

2026.03.05

PHP高性能API设计与Laravel服务架构实践
PHP高性能API设计与Laravel服务架构实践

本专题围绕 PHP 在现代 Web 后端开发中的高性能实践展开,重点讲解基于 Laravel 框架构建可扩展 API 服务的核心方法。内容涵盖路由与中间件机制、服务容器与依赖注入、接口版本管理、缓存策略设计以及队列异步处理方案。同时结合高并发场景,深入分析性能瓶颈定位与优化思路,帮助开发者构建稳定、高效、易维护的 PHP 后端服务体系。

532

2026.03.04

AI安装教程大全
AI安装教程大全

2026最全AI工具安装教程专题:包含各版本AI绘图、AI视频、智能办公软件的本地化部署手册。全篇零基础友好,附带最新模型下载地址、一键安装脚本及常见报错修复方案。每日更新,收藏这一篇就够了,让AI安装不再报错!

171

2026.03.04

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
最新Python教程 从入门到精通
最新Python教程 从入门到精通

共4课时 | 22.5万人学习

Django 教程
Django 教程

共28课时 | 5万人学习

SciPy 教程
SciPy 教程

共10课时 | 1.9万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号