Was ist der Unterschied zwischen linearer Perzeptronregression und linearer LS-Regression?

8

Kürzlich hat ein Projekt, an dem ich beteiligt bin, ein lineares Perzeptron für die multiple (21 Prädiktor-) Regression verwendet. Es wurde stochastische GD verwendet. Wie unterscheidet sich dies von der linearen OLS-Regression?

Simon Kuang
quelle
Die PerceptronKlasse, mit der Sie verknüpfen, ist eher für einen Klassifizierer (binäre Ausgabe) als für einen Regressor (kontinuierliche Ausgabe). Ist das der tatsächliche Code, den Sie verwendet haben? Wenn ja, ist das der Unterschied. :)
Dougal
@ Dougal, es zählt immer noch zu den GLMs: scikit-learn.org/stable/…
Simon Kuang
@Dougal: Angenommen, Sie hatten einen (G) LM, den Sie mit L2 optimiert haben SGDRegressor. Wäre dies gleichbedeutend mit einer linearen Regression?
Simon Kuang
Ja, einige GLMs sind Klassifikatoren. Wenn Sie verwendet SGDRegressor(loss='squared_loss', penalty='none')haben, ist das OLS.
Dougal

Antworten:

5

Die PerceptronKlasse von scikit-learn (entspricht SGDClassifier(loss="perceptron", penalty=None, learning_rate="constant", eta0=1)) verwendet die folgende Zielfunktion: In diesem Fall . Wenn das richtige Vorzeichen hat, entsteht kein Verlust; Andernfalls ergibt sich ein linearer Verlust. Insbesondere das Perzeptron verwendet eine feste Lernrate, was ebenfalls zu einer gewissen Verrücktheit bei der Optimierung führen kann.

1Ni=1Nmax(0,yiwTxi).
yi{1,1}wTxi

Die Regression der kleinsten Quadrate verwendet dagegen Hier kann beliebig real sein; Sie können ihm Klassifizierungsziele in wenn Sie möchten, aber es wird Ihnen kein sehr gutes Modell geben. Sie können dies mit optimieren, wenn Sie möchten.

1Ni=1N(yiwTxi)2.
yi{1,1}SGDRegressor(loss="squared_loss", penalty=None)

Die beiden definieren grundlegend unterschiedliche Modelle: Das Perzeptron sagt eine binäre Klassenbezeichnung mit voraus, während die lineare Regression mit einen reellen Wert vorhersagt . Diese Antwort spricht darüber, warum der Versuch, ein Klassifizierungsproblem mit einem Regressionsalgorithmus zu lösen, problematisch sein kann.sign(wTxi)wTxi

Dougal
quelle