CONNEXION
  • RetourJeux
    • Sorties
    • Hit Parade
    • Les + populaires
    • Les + attendus
    • Soluces
    • Tous les Jeux
    • Gaming
  • RetourActu Gaming
    • News
    • Astuces
    • Tests
    • Previews
    • Toute l'actu gaming
  • RetourBons plans
    • Bons plans
    • Bons plans Smartphone
    • Bons plans Hardware
    • Bons plans Image et Son
    • Bons plans Amazon
    • Bons plans Cdiscount
    • Bons plans Decathlon
    • Bons plans Fnac
    • Tous les Bons plans
  • RetourJVTech
    • Actus High-Tech
    • Intelligence Artificielle
    • Smartphones
    • Mobilité urbaine
    • Hardware
    • Image et son
    • Tutoriels
    • Tests produits High-Tech
    • Guides d'achat High-Tech
    • JVTech
  • RetourCulture
    • Actus Culture
    • Culture
  • RetourVidéos
    • A la une
    • Gaming Live
    • Vidéos Tests
    • Vidéos Previews
    • Gameplay
    • Trailers
    • Chroniques
    • Replay Web TV
    • Toutes les vidéos
  • RetourForums
    • Hardware PC
    • PS5
    • Switch 2
    • Xbox Series
    • Switch
    • Pokemon pocket
    • FC 25 Ultimate Team
    • League of Legends
    • Tous les Forums
  • PC
  • PS5
  • Xbox Series
  • Switch 2
  • PS4
  • One
  • Switch
  • iOS
  • Android
  • MMO
  • RPG
  • FPS
En ce moment Genshin Impact Valhalla Breath of the wild Animal Crossing GTA 5 Red dead 2
Liste des sujets

Aide python

rasptas
rasptas
Niveau 39
29 avril 2018 à 11:18:47

Bonjour voici l'algo:
def lineaire(X,Y): # x et y sont des listes de même taille """ fonction retournant un tuple a,b correspondant au coefficient de la régression linéaire. y=a*x+b """
n=len(X) # taille de la liste n
cov,etx = 0,0 #initialisation des variables: cov, etx ## calcul de la covariance et de l’écart type
for i in range(n):
cov= cov +(X[i]-moyenne(X))*(Y[i]-moyenne(Y))
etx= etx +(X[i]-moyenne(X))**2
return cov/etx, moyenne(Y)-cov/etx * moyenne(X)

On me demande la complexité algorithmique (2n ?) et de modifier l'algo pour réduire sa complexité :(

spf1
spf1
Niveau 12
29 avril 2018 à 11:32:57

t'appelles au moins n fois la fonction moyenne qui est linéaire, donc t'as une complexité quadratique

def lineaire(X,Y):
	n = len(X)
	x_mean, y_mean = 1/n*sum(X), 1/n*sum(Y)
	x_var = sum([(x-x_mean)**2 for x in X])
	a = sum([x*(y-y_mean) for (x,y) in zip(X,Y)])/x_var
	b = y_mean - a*x_mean
	return (a,b)
rasptas
rasptas
Niveau 39
29 avril 2018 à 11:48:10

Je vois, merci beaucoup !

Pseudo supprimé
Pseudo supprimé 29 avril 2018 à 12:17:36

Le 29 avril 2018 à 11:32:57 Spf1 a écrit :
t'appelles au moins n fois la fonction moyenne qui est linéaire, donc t'as une complexité quadratique

def lineaire(X,Y):
	n = len(X)
	x_mean, y_mean = 1/n*sum(X), 1/n*sum(Y)
	x_var = sum([(x-x_mean)**2 for x in X])
	a = sum([x*(y-y_mean) for (x,y) in zip(X,Y)])/x_var
	b = y_mean - a*x_mean
	return (a,b)

On appelle moyenne exactement 3n fois non?

spf1
spf1
Niveau 12
29 avril 2018 à 12:29:51

Le 29 avril 2018 à 12:17:36 Pitoxdentel00 a écrit :
On appelle moyenne exactement 3n fois non?

3n+2 :)

Pseudo supprimé
Pseudo supprimé 29 avril 2018 à 21:46:35

Effectivement j'avais pas vu le return :)

Sous forums
  • Métiers & Orientation
  • Histoire
  • Cours et Devoirs
  • Politique
  • Environnement & Nature
  • Philosophie