如何绘制分类算法的theta向量线(MATLAB)

在进行逻辑回归后,我得到了一个theta向量,如[-0.34, -4.5, 0.5]。我如何使用这个向量在图中绘制边界线?


回答:

在二元分类的逻辑回归中,新样本x被分类为0或1的概率为:

enter image description here

因此,决策边界对应于P(y=1|x)=P(y=0|x)=sigmoid(theta'*x)=0.5的线,这对应于theta'*x=0。Sigmoid函数为sigmoid = @(z) 1.0 ./ (1.0 + exp(-z))

enter image description here

在我们的案例中,数据有两个维度加上偏置,因此:

enter image description here

例如,x1在[-1 1]范围内的决策边界可以表示为:

theta = [-0.34, -4.5, 0.5];sigmoid = @(z) 1.0 ./ (1.0 + exp(-z));% 随机点N = 100;X1 = 2*rand(N,1)-1;X2 = 20*rand(N,1)-10;x = [ones(N,1), X1(:), X2(:)];y = sigmoid(theta * x.') > 0.5;% 边界线plot_x = [-1 1];plot_y = (-1./theta(3)).*(theta(2).*plot_x + theta(1));% 绘图figure; hold on;scatter(X1(y==1),X2(y==1),'bo');scatter(X1(y==0),X2(y==0),'rx');plot(plot_x, plot_y, 'k--');hold offxlabel('x1');  ylabel('x2');title('x_{2} = 0.68 + 9 x_{1}');axis([-1 1 -10 10]);

它生成以下图表:

enter image description here

Related Posts

使用LSTM在Python中预测未来值

这段代码可以预测指定股票的当前日期之前的值,但不能预测…

如何在gensim的word2vec模型中查找双词组的相似性

我有一个word2vec模型,假设我使用的是googl…

dask_xgboost.predict 可以工作但无法显示 – 数据必须是一维的

我试图使用 XGBoost 创建模型。 看起来我成功地…

ML Tuning – Cross Validation in Spark

我在https://spark.apache.org/…

如何在React JS中使用fetch从REST API获取预测

我正在开发一个应用程序,其中Flask REST AP…

如何分析ML.NET中多类分类预测得分数组?

我在ML.NET中创建了一个多类分类项目。该项目可以对…

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注