改进 ML.NET 模型
了解如何改进 ML.NET 模型。
重新定义问题
有时,改进模型可能与用于训练模型的数据或技术无关。 相反,可能只是提出了错误的问题。 考虑从不同的角度看待问题,并利用数据提取潜在指示和隐藏关系,以便优化问题。
提供更多数据示例
与人类一样,训练算法获得的训练越多,其性能表现就可能越好。 提高模型性能的方法之一是为算法提供更多训练数据示例。 模型从中进行学习的数据越多,模型能够正确识别的案例就越多。
为数据添加上下文
单个数据点的含义可能难以解读。 围绕数据点生成上下文有助于算法和主题专家更好地做出决策。 例如,一栋房子有三间卧室本身并不能很好地指示其价格。 然而,如果你添加背景信息,并现在知道它位于一个主要大都市区外的郊区社区,平均年龄为38岁,平均家庭收入为8万美元,学校排名前20%,那么这个算法就有更多的信息来作为决策依据。 所有这些上下文都可以作为特征添加到机器学习模型的输入中。
使用有意义的数据和特征
虽然更多的数据示例和特征可以帮助提高模型的准确性,但它们也可能会引入干扰,因为并非所有数据和特征都有意义。 因此,了解哪些特征对算法所做的决策具有最大影响非常重要。 使用排列特征重要性 (PFI) 等技术可以帮助识别这些突出的特征,这不仅有助于解释模型,还可以使用输出作为特征选择方法来减少进入训练过程的干扰特征的数量。
有关使用 PFI 的详细信息,请参阅使用排列特征重要性解释模型预测。
交叉验证
交叉验证是一种训练和模型评估技术,可将数据拆分为多个分区,并利用这些分区训练多个算法。 此技术通过保留来自训练过程的数据来提高模型的可靠性。 除提高不可见观测的性能之外,在数据受限的环境中,它还可用作使用较小数据集训练模型的有效工具。
有关详细信息,请参阅 如何在 ML.NET中使用交叉验证。
超参数优化
训练机器学习模型是一个迭代和探索的过程。 例如,使用 K-Means 算法训练模型时,最优群集数是多少? 答案取决于许多因素,例如数据的结构。 找到该数字需要尝试不同的 k 值,然后通过评估性能来确定最佳值。 优化这些引导训练过程来查找最佳模型的参数的做法称为超参数优化。
选择其他算法
回归和分类等机器学习任务包含各种算法实现。 可能出现尝试解决的问题和数据的构造方式与当前算法不能很好地匹配的情况。 在此类情况下,请考虑为任务使用其他算法,查看它是否能够从数据中更好地学习。
以下链接提供有关如何选择算法的更多指导。