Ajustement linéaire aux échantillons de données d'une fonction logistique

Aug 17 2020

Supposons que j'échantillonne uniformément des points de données à partir d'un intervalle [-$a$;$a$], puis passez ces points de données à une fonction logistique de la forme

$f(x) = \frac{1}{1+e^{-\beta\cdot x}}$,

et ajuster une ligne linéaire à ces échantillons de données (x, f(x)). La pente attendue de cet ajustement linéaire peut-elle être exprimée en fonction de$\beta$et$a$?

(Bonus : fonction tangens hyperbolicus$f(x)=\tanh(\beta x)$au lieu de la fonction logistique)

Réponses

2 jld Aug 18 2020 at 02:08

Vous avez des données$X_1,\dots,X_n\stackrel{\text{iid}}\sim\text{Unif}(-a,a)$et obtenir$Y_i = \sigma(X_i)$$\sigma(z) = \frac{1}{1+e^{-bx}}$.

La pente de population d'une régression linéaire simple est$\newcommand{\E}{\operatorname{E}}$ $$ \beta := \frac{\text{Cov}(X_i, Y_i)}{\text{Var}(X_i)} = \frac{\E(X\sigma(X)) - (\E X) (\E \sigma(X))}{\text{Var}(X)}. $$ $X$est symétrique par rapport à$0$et la variance est juste celle d'un RV uniforme qui est connu, donc tout ce que nous avons vraiment besoin de calculer est$\E(X\sigma(X))$. C'est$$ \E(X\sigma(X)) = \frac 1{2a} \int_{-a}^a \frac{x}{1+e^{-bx}}\,\text dx. $$Nous pouvons noter que$$ \int \frac{1}{e^{-bx} + 1}\,\text dx = \int \frac{e^{bx}}{1 + e^{bx}}\,\text dx \\ = \frac 1b \int \frac 1u \,\text du = \frac 1b \log (e^{bx} + 1) $$donc on peut intégrer par parties pour obtenir$$ \E(X\sigma(X)) = \frac{1}{2ab}x\log(e^{bx}+1)\bigg\vert_{-a}^a - \frac 1{2ab}\int_{-a}^a \log(e^{bx} + 1)\,\text dx. $$Avec le premier terme (mis à part quelques constantes d'échelle), nous nous retrouvons avec$$ \log(e^{ab}+1) + \log(e^{-ab}+1) = \log\left[e^{ab}(e^{-ab}+1)\right] + \log(e^{-ab}+1) \\ = ab + 2\log(e^{-ab}+1) $$alors$$ \frac{1}{2ab}x\log(e^{bx}+1)\bigg\vert_{-a}^a = \frac a2 + \frac 1b \log(e^{-ab}+1). $$Pour l'autre terme, on peut laisser$u = -e^{bx}$alors$\frac 1{bu}\,\text du = \text dx$ce qui signifie$\newcommand{\Li}{\operatorname{Li}_2}$ $$ \int_{-a}^a \log(e^{bx} + 1)\,\text dx = -\frac 1b \int_{-e^{ab}}^{e^{ab}} \frac{\log(1-u)}u\,\text du \\ = \frac 1b\left[\Li(e^{ab}) - \Li(-e^{ab})\right] $$$\Li$est la fonction dilogarithme . Tous ensemble, cela signifie$$ \E(X \sigma(X)) = \frac a2 + \frac 1b \log(e^{-ab}+1) + \frac{\Li(-e^{ab}) - \Li(-e^{-ab})}{2ab^2}. $$j'ai quelque chose de la forme$\Li(z) - \Li(1/z)$. Utilisant le fait que$$ \Li(z) + \Li(1/z) = -\frac{\pi^2}6 - \frac 12 \log^2(-z) $$Je peux réécrire cela avec juste un seul$\Li$dedans :$$ \E(X \sigma(X)) = \frac a2 + \frac 1b \log(e^{-ab}+1) + \frac{-\frac{\pi^2}6 - \frac 12 a^2b^2 - 2 \Li(-e^{-ab})}{2ab^2} \\ = \frac a4 + \frac 1b \log(e^{-ab}+1) - \frac{\pi^2 + 12 \Li(-e^{-ab})}{12ab^2}. $$Ça signifie$$ \beta(a,b) = \frac{\frac a4 + \frac 1b \log(e^{-ab}+1) - \frac{\pi^2 + 12 \Li(-e^{-ab})}{12ab^2}}{a^2/3} \\ = \frac{3}{4a} + \frac{3}{a^2b}\log(e^{-ab}+1) - \frac{\pi^2 + 12 \Li(-e^{-ab})}{4a^3b^2}. $$

$\Li$est une fonction spéciale et ne peut pas être exprimée en termes de fonctions élémentaires en général, et puisque cela pourrait être résolu pour$\Li$cela signifie qu'il n'y a pas d'expression élémentaire générale pour$\beta$. Mais nous pouvons l'évaluer en termes de fonctions élémentaires pour des valeurs particulières de$a$et$b$. Une telle valeur est$$ \Li\left(-\varphi\right) = -\frac{\pi^2}{10} - \log^2\varphi $$donc si$ab = -\log(\varphi)$alors nous pourrons évaluer$\beta$en termes de fonctions élémentaires. A titre d'exemple, nous pourrions prendre$$ a = \sqrt 2 \\ b = -\frac 1{\sqrt 2}\log(\varphi). $$Bien que ce soit encore une expression vraiment désordonnée même si ce n'est qu'en termes de fonctions élémentaires.

C'était beaucoup de travail juste pour exprimer l'intégrale$\int_{-a}^a \frac{x}{1+e^{-bx}}\,\text dx$en termes d'intégrale différente, mais je pense que la valeur est qu'elle montre qu'il n'y a pas de forme fermée pour$\beta(a,b)$qui nous manque, et cela le relie à une fonction spéciale bien étudiée qui a des implémentations de haute qualité disponibles.

Voici une simulation à vérifier.

set.seed(111)
nsim <- 1e6
a <- 2.34
b <- 1.2
x <- runif(nsim, -a, a)
y <- 1 / (1 + exp(-b * x))

curve(plogis(b*x), -a, a, 500, col=4)
points(y[1:100]~x[1:100], cex=.5)

# I'm just integrating to avoid needing to load other libraries
Li2 <- function(z) -integrate(function(u) log(1-u)/u, 0, z)$value
slopefunc <- function(a,b) {
  3/(4*a) + 3 / (a^2 * b) * log(exp(-a*b) + 1) - (pi^2 + 12*Li2(-exp(-a*b))) / (4*a^3*b^2)
}

lm(y~x)$coef[2]
slopefunc(a,b)
cov(x, y) / var(x)