Hauspreisvorhersage

Nov 03, 2024 pm 12:28 PM

In der Welt der Immobilien hängt die Bestimmung der Immobilienpreise von zahlreichen Faktoren ab, von Lage und Größe bis hin zu Ausstattung und Markttrends. Die einfache lineare Regression, eine grundlegende Technik des maschinellen Lernens, bietet eine praktische Möglichkeit, Immobilienpreise basierend auf Schlüsselmerkmalen wie der Anzahl der Zimmer oder der Quadratmeterzahl vorherzusagen.

In diesem Artikel beschäftige ich mich mit dem Prozess der Anwendung einer einfachen linearen Regression auf einen Wohnungsdatensatz, von der Datenvorverarbeitung und Funktionsauswahl bis hin zum Aufbau eines Modells, das wertvolle Einblicke in die Preise bieten kann. Egal, ob Sie neu in der Datenwissenschaft sind oder Ihr Verständnis vertiefen möchten, dieses Projekt dient als praktische Erkundung, wie datengesteuerte Vorhersagen zu intelligenteren Immobilienentscheidungen führen können.

Das Wichtigste zuerst: Sie beginnen mit dem Importieren Ihrer Bibliotheken:

import pandas as pd
import seaborn as sns
import numpy as np
import matplotlib.pyplot as plt
Nach dem Login kopieren
Nach dem Login kopieren
#Read from the directory where you stored the data

data  = pd.read_csv('/kaggle/input/california-housing-prices/housing.csv')
Nach dem Login kopieren
Nach dem Login kopieren
data
Nach dem Login kopieren
Nach dem Login kopieren

Hauspreisvorhersage

Hauspreisvorhersage

#Test to see if there arent any null values
data.info()
Nach dem Login kopieren
Nach dem Login kopieren

Hauspreisvorhersage

#Trying to draw the same number of null values
data.dropna(inplace = True)
Nach dem Login kopieren
Nach dem Login kopieren
data.info()
Nach dem Login kopieren
Nach dem Login kopieren

Hauspreisvorhersage

#From our data, we are going to train and test our data

from sklearn.model_selection import train_test_split

X = data.drop(['median_house_value'], axis = 1)
y = data['median_house_value']
Nach dem Login kopieren
Nach dem Login kopieren
y
Nach dem Login kopieren
Nach dem Login kopieren

Hauspreisvorhersage

X_train, X_test, y_train, y_test = train_test_split(X, y, test_size = 0.2)
Nach dem Login kopieren
Nach dem Login kopieren
#Examining correlation between x and y training data
train_data = X_train.join(y_train)
Nach dem Login kopieren
Nach dem Login kopieren
train_data
Nach dem Login kopieren
Nach dem Login kopieren
Nach dem Login kopieren

Hauspreisvorhersage

Hauspreisvorhersage

#Visualizing the above
train_data.hist(figsize=(15, 8))
Nach dem Login kopieren
Nach dem Login kopieren

Hauspreisvorhersage

#Encoding non-numeric columns to see if they are useful and categorical for analysis

train_data_encoded = pd.get_dummies(train_data, drop_first=True)
correlation_matrix = train_data_encoded.corr()
print(correlation_matrix)
Nach dem Login kopieren
Nach dem Login kopieren

Hauspreisvorhersage

Hauspreisvorhersage

Hauspreisvorhersage

train_data_encoded.corr()
Nach dem Login kopieren
Nach dem Login kopieren

Hauspreisvorhersage

Hauspreisvorhersage

Hauspreisvorhersage

plt.figure(figsize=(15,8))
sns.heatmap(train_data_encoded.corr(), annot=True, cmap = "inferno")
Nach dem Login kopieren
Nach dem Login kopieren

Hauspreisvorhersage

import pandas as pd
import seaborn as sns
import numpy as np
import matplotlib.pyplot as plt
Nach dem Login kopieren
Nach dem Login kopieren
#Read from the directory where you stored the data

data  = pd.read_csv('/kaggle/input/california-housing-prices/housing.csv')
Nach dem Login kopieren
Nach dem Login kopieren

Hauspreisvorhersage

data
Nach dem Login kopieren
Nach dem Login kopieren

ocean_proximity
INLAND 5183
NEAR OCEAN 2108
IN DER NÄHE VON BAY 1783
INSEL 5
Name: count, dtype: int64

#Test to see if there arent any null values
data.info()
Nach dem Login kopieren
Nach dem Login kopieren

Hauspreisvorhersage

#Trying to draw the same number of null values
data.dropna(inplace = True)
Nach dem Login kopieren
Nach dem Login kopieren
data.info()
Nach dem Login kopieren
Nach dem Login kopieren

Hauspreisvorhersage

Hauspreisvorhersage

#From our data, we are going to train and test our data

from sklearn.model_selection import train_test_split

X = data.drop(['median_house_value'], axis = 1)
y = data['median_house_value']
Nach dem Login kopieren
Nach dem Login kopieren

Hauspreisvorhersage

y
Nach dem Login kopieren
Nach dem Login kopieren

Hauspreisvorhersage

X_train, X_test, y_train, y_test = train_test_split(X, y, test_size = 0.2)
Nach dem Login kopieren
Nach dem Login kopieren
#Examining correlation between x and y training data
train_data = X_train.join(y_train)
Nach dem Login kopieren
Nach dem Login kopieren

Hauspreisvorhersage

train_data
Nach dem Login kopieren
Nach dem Login kopieren
Nach dem Login kopieren

Hauspreisvorhersage

#Visualizing the above
train_data.hist(figsize=(15, 8))
Nach dem Login kopieren
Nach dem Login kopieren
#Encoding non-numeric columns to see if they are useful and categorical for analysis

train_data_encoded = pd.get_dummies(train_data, drop_first=True)
correlation_matrix = train_data_encoded.corr()
print(correlation_matrix)
Nach dem Login kopieren
Nach dem Login kopieren
train_data_encoded.corr()
Nach dem Login kopieren
Nach dem Login kopieren
plt.figure(figsize=(15,8))
sns.heatmap(train_data_encoded.corr(), annot=True, cmap = "inferno")
Nach dem Login kopieren
Nach dem Login kopieren
train_data['total_rooms'] = np.log(train_data['total_rooms'] + 1)
train_data['total_bedrooms'] = np.log(train_data['total_bedrooms'] +1)
train_data['population'] = np.log(train_data['population'] + 1)
train_data['households'] = np.log(train_data['households'] + 1)
Nach dem Login kopieren
train_data.hist(figsize=(15, 8))
Nach dem Login kopieren

0,5092972905670141

#convert ocean_proximity factors into binary's using one_hot_encoding
train_data.ocean_proximity.value_counts()
Nach dem Login kopieren

Hauspreisvorhersage

#For each feature of the above we will then create its binary(0 or 1)
pd.get_dummies(train_data.ocean_proximity)
Nach dem Login kopieren

0,4447616558596853

#Dropping afterwards the proximity
train_data = train_data.join(pd.get_dummies(train_data.ocean_proximity)).drop(['ocean_proximity'], axis=1)
Nach dem Login kopieren

Hauspreisvorhersage

train_data
Nach dem Login kopieren
Nach dem Login kopieren
Nach dem Login kopieren

Hauspreisvorhersage

#recheck for correlation
plt.figure(figsize=(18, 8))
sns.heatmap(train_data.corr(), annot=True, cmap ='twilight')
Nach dem Login kopieren

0,5384474921332503

Ich würde wirklich sagen, dass das Trainieren einer Maschine nicht der einfachste Prozess ist, aber um die oben genannten Ergebnisse weiter zu verbessern, können Sie weitere Funktionen unter dem param_grid hinzufügen, wie z. B. das min_feature, und auf diese Weise kann sich Ihr bester Schätzerwert weiter verbessern.

Wenn Sie bis hierher gekommen sind, liken und teilen Sie bitte Ihren Kommentar unten, Ihre Meinung ist wirklich wichtig. Vielen Dank!??❤️

Das obige ist der detaillierte Inhalt vonHauspreisvorhersage. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Erklärung dieser Website
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn

Heiße Artikel -Tags

Notepad++7.3.1

Notepad++7.3.1

Einfach zu bedienender und kostenloser Code-Editor

SublimeText3 chinesische Version

SublimeText3 chinesische Version

Chinesische Version, sehr einfach zu bedienen

Senden Sie Studio 13.0.1

Senden Sie Studio 13.0.1

Leistungsstarke integrierte PHP-Entwicklungsumgebung

Dreamweaver CS6

Dreamweaver CS6

Visuelle Webentwicklungstools

SublimeText3 Mac-Version

SublimeText3 Mac-Version

Codebearbeitungssoftware auf Gottesniveau (SublimeText3)

Wie benutze ich eine schöne Suppe, um HTML zu analysieren? Wie benutze ich eine schöne Suppe, um HTML zu analysieren? Mar 10, 2025 pm 06:54 PM

Wie benutze ich eine schöne Suppe, um HTML zu analysieren?

Bildfilterung in Python Bildfilterung in Python Mar 03, 2025 am 09:44 AM

Bildfilterung in Python

So verwenden Sie Python, um die ZiPF -Verteilung einer Textdatei zu finden So verwenden Sie Python, um die ZiPF -Verteilung einer Textdatei zu finden Mar 05, 2025 am 09:58 AM

So verwenden Sie Python, um die ZiPF -Verteilung einer Textdatei zu finden

Wie man mit PDF -Dokumenten mit Python arbeitet Wie man mit PDF -Dokumenten mit Python arbeitet Mar 02, 2025 am 09:54 AM

Wie man mit PDF -Dokumenten mit Python arbeitet

Wie kann man mit Redis in Django -Anwendungen zwischenstrichen Wie kann man mit Redis in Django -Anwendungen zwischenstrichen Mar 02, 2025 am 10:10 AM

Wie kann man mit Redis in Django -Anwendungen zwischenstrichen

Wie führe ich ein tiefes Lernen mit Tensorflow oder Pytorch durch? Wie führe ich ein tiefes Lernen mit Tensorflow oder Pytorch durch? Mar 10, 2025 pm 06:52 PM

Wie führe ich ein tiefes Lernen mit Tensorflow oder Pytorch durch?

Serialisierung und Deserialisierung von Python -Objekten: Teil 1 Serialisierung und Deserialisierung von Python -Objekten: Teil 1 Mar 08, 2025 am 09:39 AM

Serialisierung und Deserialisierung von Python -Objekten: Teil 1

So implementieren Sie Ihre eigene Datenstruktur in Python So implementieren Sie Ihre eigene Datenstruktur in Python Mar 03, 2025 am 09:28 AM

So implementieren Sie Ihre eigene Datenstruktur in Python

See all articles