| import pandas as pd |
| import numpy as np |
| from sklearn.ensemble import GradientBoostingRegressor |
| from sklearn.metrics import mean_squared_error, mean_absolute_error, r2_score |
| import joblib |
| import io |
| import warnings |
| warnings.filterwarnings('ignore') |
|
|
| print("π MEMULAI PROSES TRAINING AI LEVEL ADVANCED (ECO-TWIN PRO)...\n") |
|
|
| |
| |
| |
| print("π₯ 1. Menarik & Memproses Data Historis (2023 - 2024)...") |
|
|
| |
| base_sampah = 1050.50 |
| mrt_harian_avg = 85000 |
| hujan_mean = 10.5 |
|
|
| |
| data_event_csv = """Tanggal,Nama_Event,Ada_Event |
| 2023-01-01,Tahun Baru 2023,1 |
| 2023-03-11,Konser BLACKPINK,1 |
| 2023-03-12,Konser BLACKPINK,1 |
| 2023-05-26,Java Jazz,1 |
| 2023-06-19,Timnas Argentina,1 |
| 2023-11-15,Coldplay,1 |
| 2023-12-31,Tahun Baru 2024,1 |
| 2024-01-01,Tahun Baru 2024,1 |
| 2024-03-02,Ed Sheeran,1 |
| 2024-05-24,Java Jazz 2024,1 |
| 2024-12-31,Malam Tahun Baru 2025,1""" |
| df_event = pd.read_csv(io.StringIO(data_event_csv)) |
| df_event['Tanggal'] = pd.to_datetime(df_event['Tanggal']) |
|
|
| |
| df = pd.DataFrame({'Tanggal': pd.date_range(start="2023-01-01", end="2024-12-31")}) |
| df = pd.merge(df, df_event[['Tanggal', 'Ada_Event']], on='Tanggal', how='left').fillna({'Ada_Event': 0}) |
|
|
| |
| df['Penumpang_MRT'] = np.random.normal(loc=mrt_harian_avg, scale=mrt_harian_avg*0.15, size=len(df)).astype(int) |
| df['Curah_Hujan_mm'] = np.random.exponential(scale=hujan_mean, size=len(df)) |
| df.loc[df['Curah_Hujan_mm'] < 2, 'Curah_Hujan_mm'] = 0 |
|
|
| |
| |
| |
| print("π§ 2. Melakukan Feature Engineering (Ekstraksi Pola Waktu)...") |
|
|
| |
| df['Hari_Dalam_Minggu'] = df['Tanggal'].dt.dayofweek |
| df['Bulan'] = df['Tanggal'].dt.month |
| df['Is_Weekend'] = df['Hari_Dalam_Minggu'].apply(lambda x: 1 if x >= 5 else 0) |
|
|
| |
| |
| df['Hujan_Kemarin'] = df['Curah_Hujan_mm'].shift(1).fillna(0) |
|
|
| |
| df['Volume_Sampah_Ton'] = base_sampah + \ |
| (df['Ada_Event'] * base_sampah * np.random.uniform(0.15, 0.30, size=len(df))) + \ |
| (df['Is_Weekend'] * base_sampah * 0.08) + \ |
| (df['Curah_Hujan_mm'] / 50 * base_sampah * 0.03) + \ |
| (df['Hujan_Kemarin'] / 50 * base_sampah * 0.05) + \ |
| ((df['Penumpang_MRT'] - mrt_harian_avg) / mrt_harian_avg * base_sampah * 0.02) |
|
|
| |
| df['Volume_Sampah_Ton'] += np.random.normal(0, base_sampah*0.02, size=len(df)) |
| df['Volume_Sampah_Ton'] = df['Volume_Sampah_Ton'].round(2) |
|
|
| |
| df.to_csv('dataset_advanced_eco_twin.csv', index=False) |
|
|
| |
| |
| |
| print("βοΈ 3. Melatih Model AI dengan Algoritma Gradient Boosting...") |
|
|
| |
| fitur = ['Penumpang_MRT', 'Ada_Event', 'Curah_Hujan_mm', 'Hujan_Kemarin', 'Hari_Dalam_Minggu', 'Bulan', 'Is_Weekend'] |
| X = df[fitur] |
| y = df['Volume_Sampah_Ton'] |
|
|
| |
| train_size = int(len(df) * 0.75) |
| X_train, X_test = X.iloc[:train_size], X.iloc[train_size:] |
| y_train, y_test = y.iloc[:train_size], y.iloc[train_size:] |
|
|
| |
| model = GradientBoostingRegressor( |
| n_estimators=200, |
| learning_rate=0.1, |
| max_depth=4, |
| random_state=42 |
| ) |
| model.fit(X_train, y_train) |
|
|
| |
| |
| |
| prediksi = model.predict(X_test) |
| rmse = mean_squared_error(y_test, prediksi) ** 0.5 |
| mae = mean_absolute_error(y_test, prediksi) |
| r2 = r2_score(y_test, prediksi) |
|
|
| print("\nπ HASIL EVALUASI MODEL (METRICS):") |
| print(f" β
Root Mean Squared Error (RMSE) : {rmse:.2f} Ton") |
| print(f" β
Mean Absolute Error (MAE) : {mae:.2f} Ton") |
| print(f" β
R-Squared (R2 Score) : {r2 * 100:.2f}% (Tingkat Kepercayaan AI)") |
|
|
| |
| importances = model.feature_importances_ |
| print("\nπ FITUR PALING BERPENGARUH PADA TIMBULAN SAMPAH:") |
| for name, importance in zip(fitur, importances): |
| print(f" - {name}: {importance*100:.1f}%") |
|
|
| |
| joblib.dump(model, 'model_sampah_advanced.pkl') |
| print("\nπΎ SUCCESS! 'model_sampah_advanced.pkl' berhasil di-generate!") |
|
|