GoshawkVortexAI commited on
Commit
095dd0b
·
verified ·
1 Parent(s): 65b7993

Upload app-7.py

Browse files
Files changed (1) hide show
  1. app-7.py +294 -0
app-7.py ADDED
@@ -0,0 +1,294 @@
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
1
+ import gradio as gr
2
+ import math
3
+
4
+ # ─────────────────────────────────────────────
5
+ # CORE SCIENCE ENGINE
6
+ # ─────────────────────────────────────────────
7
+
8
+ STAR_TYPES = {
9
+ "O": {"hz_min": 100, "hz_max": 200, "uv_risk": 10, "lifespan_gyr": 0.01},
10
+ "B": {"hz_min": 50, "hz_max": 100, "uv_risk": 9, "lifespan_gyr": 0.1},
11
+ "A": {"hz_min": 15, "hz_max": 40, "uv_risk": 7, "lifespan_gyr": 2},
12
+ "F": {"hz_min": 1.5, "hz_max": 3.0, "uv_risk": 5, "lifespan_gyr": 4},
13
+ "G": {"hz_min": 0.9, "hz_max": 1.5, "uv_risk": 3, "lifespan_gyr": 10},
14
+ "K": {"hz_min": 0.3, "hz_max": 0.9, "uv_risk": 2, "lifespan_gyr": 30},
15
+ "M": {"hz_min": 0.1, "hz_max": 0.3, "uv_risk": 4, "lifespan_gyr": 100},
16
+ }
17
+
18
+ def clamp(value, lo=0, hi=100):
19
+ return max(lo, min(hi, value))
20
+
21
+ def analyze_planet(planet_name, radius_earth, mass_earth,
22
+ temperature_k, stellar_flux, star_type, orbital_period_days):
23
+
24
+ star = STAR_TYPES.get(star_type.upper(), STAR_TYPES["G"])
25
+ risks = []
26
+
27
+ # ── 1. GRAVITY SUITABILITY ──────────────────────────────
28
+ # Simple approximation: g ∝ mass / radius²
29
+ surface_gravity = mass_earth / (radius_earth ** 2)
30
+ if 0.5 <= surface_gravity <= 2.0:
31
+ gravity_score = 100
32
+ gravity_label = "✅ Uygun (%.2fg)" % surface_gravity
33
+ elif surface_gravity < 0.5:
34
+ gravity_score = clamp(surface_gravity / 0.5 * 80)
35
+ gravity_label = "⚠️ Düşük yerçekimi (%.2fg)" % surface_gravity
36
+ risks.append("Düşük yerçekimi atmosfer kaybına yol açabilir.")
37
+ elif surface_gravity <= 3.0:
38
+ gravity_score = clamp(100 - (surface_gravity - 2.0) * 30)
39
+ gravity_label = "⚠️ Yüksek yerçekimi (%.2fg)" % surface_gravity
40
+ risks.append("Yüksek yerçekimi biyolojik yapıları zorlayabilir.")
41
+ else:
42
+ gravity_score = clamp(100 - (surface_gravity - 2.0) * 25)
43
+ gravity_label = "❌ Aşırı yerçekimi (%.2fg)" % surface_gravity
44
+ risks.append("Aşırı yerçekimi çok hücreli yaşamla uyumsuz olabilir.")
45
+
46
+ # ── 2. TEMPERATURE & LIQUID WATER ───────────────────────
47
+ LIQUID_MIN, LIQUID_MAX = 273, 373 # Kelvin (1 atm baseline)
48
+ if LIQUID_MIN <= temperature_k <= LIQUID_MAX:
49
+ temp_score = 100
50
+ water_label = "✅ Sıvı su mümkün (%d K)" % temperature_k
51
+ elif temperature_k < 273:
52
+ delta = 273 - temperature_k
53
+ temp_score = clamp(100 - delta * 1.2)
54
+ water_label = "🧊 Donma riski (%d K)" % temperature_k
55
+ risks.append("Sıcaklık donma noktasının altında – sıvı su kısıtlı.")
56
+ else:
57
+ delta = temperature_k - 373
58
+ temp_score = clamp(100 - delta * 1.5)
59
+ water_label = "🔥 Kaynama riski (%d K)" % temperature_k
60
+ risks.append("Yüksek sıcaklık yüzey suyunu buharlaştırabilir.")
61
+
62
+ # ── 3. STELLAR FLUX & ATMOSPHERE STABILITY ──────────────
63
+ # Earth baseline ≈ 1.0 S⊕
64
+ if 0.5 <= stellar_flux <= 1.5:
65
+ flux_score = 100
66
+ atm_label = "✅ Kararlı enerji akısı (%.2f S⊕)" % stellar_flux
67
+ elif stellar_flux < 0.5:
68
+ flux_score = clamp(stellar_flux / 0.5 * 80)
69
+ atm_label = "❄️ Düşük akı – buzul riski (%.2f S⊕)" % stellar_flux
70
+ risks.append("Düşük yıldız akısı global donmaya neden olabilir.")
71
+ elif stellar_flux <= 2.5:
72
+ flux_score = clamp(100 - (stellar_flux - 1.5) * 40)
73
+ atm_label = "☀️ Yüksek akı – ısınma riski (%.2f S⊕)" % stellar_flux
74
+ risks.append("Venüs benzeri sera etkisi riski mevcut.")
75
+ else:
76
+ flux_score = clamp(100 - (stellar_flux - 2.5) * 30)
77
+ atm_label = "🌋 Aşırı akı – sera etkisi (%.2f S⊕)" % stellar_flux
78
+ risks.append("Yoğun atmosfer erozyonu ve radyasyon tehdidi.")
79
+
80
+ # ── 4. RADIATION RISK ───────────────────────────────────
81
+ uv_base = star["uv_risk"]
82
+ # M dwarfları flare riski taşır
83
+ if star_type.upper() == "M":
84
+ risks.append("M cüce yıldızları sık güneş patlaması (flare) üretir – radyasyon dalgalanmaları.")
85
+ if orbital_period_days < 10 and star_type.upper() in ("M", "K"):
86
+ risks.append("Kısa orbital periyot: tidal kilitlenme (tidal locking) ihtimali yüksek.")
87
+
88
+ radiation_score = clamp(100 - uv_base * 8)
89
+ rad_label = {
90
+ 1: "✅ Minimum radyasyon", 2: "✅ Düşük radyasyon",
91
+ 3: "✅ Orta-düşük radyasyon", 4: "⚠️ Orta radyasyon",
92
+ 5: "⚠️ Yüksek radyasyon", 6: "❌ Tehlikeli radyasyon",
93
+ 7: "❌ Çok tehlikeli", 8: "❌ Ölümcül", 9: "☢️ Şiddetli",
94
+ 10: "☢️ Felaket seviyesi"
95
+ }.get(uv_base, "⚠️ Bilinmeyen")
96
+
97
+ # ── 5. SIZE SUITABILITY ──────────────────────────────────
98
+ if 0.5 <= radius_earth <= 1.8:
99
+ size_bonus = 10
100
+ elif radius_earth < 0.5:
101
+ size_bonus = -10
102
+ risks.append("Çok küçük gezegen – atmosfer tutma kapasitesi sınırlı.")
103
+ elif radius_earth <= 2.5:
104
+ size_bonus = 0
105
+ else:
106
+ size_bonus = -15
107
+ risks.append("Süper-Jüpiter veya mini-Neptün sınırında – kayalık yüzey olmayabilir.")
108
+
109
+ # ── 6. ORBITAL PERIOD BONUS ─────────────────────────────
110
+ hz_min = star["hz_min"]
111
+ hz_max = star["hz_max"]
112
+ orbital_au_approx = (orbital_period_days / 365.25) ** (2/3)
113
+ if hz_min <= orbital_au_approx <= hz_max:
114
+ orbital_bonus = 5
115
+ else:
116
+ orbital_bonus = -5
117
+ risks.append("Yörünge yaşanabilir bölge (habitable zone) dışında görünüyor.")
118
+
119
+ # ── COMPOSITE SCORES ────────────────────────────────────
120
+ habitability_score = clamp(
121
+ gravity_score * 0.25 +
122
+ temp_score * 0.35 +
123
+ flux_score * 0.20 +
124
+ radiation_score * 0.20 +
125
+ size_bonus + orbital_bonus
126
+ )
127
+
128
+ # Life probability: daha temkinli, logaritmik
129
+ life_base = habitability_score
130
+ star_life_factor = min(star["lifespan_gyr"] / 4.0, 2.5) # evrim için zaman
131
+ life_probability = clamp(life_base * 0.6 * min(star_life_factor, 1.5))
132
+
133
+ # ── VERDICT ─────────────────────────────────────────────
134
+ if habitability_score >= 70:
135
+ verdict = "🟢 YAŞANABİLİR"
136
+ elif habitability_score >= 40:
137
+ verdict = "🟡 KISMİ (Koşullu)"
138
+ else:
139
+ verdict = "🔴 YAŞANAMAz"
140
+
141
+ # ── FORMAT OUTPUT ───────────────────────────────────────
142
+ explanation = build_explanation(
143
+ planet_name, star_type, radius_earth, mass_earth,
144
+ temperature_k, stellar_flux, orbital_period_days,
145
+ surface_gravity, orbital_au_approx, star
146
+ )
147
+
148
+ output = f"""
149
+ ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
150
+ 🪐 PLANET: {planet_name.upper()}
151
+ ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
152
+
153
+ 🌍 HABITABİLİTY SCORE : {habitability_score:.1f} / 100
154
+ 👽 ALIEN LIFE PROBABILITY: {life_probability:.1f} %
155
+
156
+ ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
157
+ 📊 ALT ANALİZ
158
+ ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
159
+
160
+ 🌡️ Sıvı Su Potansiyeli : {water_label}
161
+ 🛡️ Atmosfer Kararlılığı : {atm_label}
162
+ ☢️ Radyasyon Riski : {rad_label}
163
+ ⚖️ Yerçekimi Uygunluğu : {gravity_label}
164
+
165
+ ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
166
+ 🧠 BİLİMSEL AÇIKLAMA
167
+ ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
168
+
169
+ {explanation}
170
+
171
+ ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
172
+ ⚠️ RİSK FAKTÖRLERİ
173
+ ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
174
+
175
+ """
176
+ if risks:
177
+ for r in risks:
178
+ output += f" • {r}\n"
179
+ else:
180
+ output += " ✅ Kritik risk faktörü tespit edilmedi.\n"
181
+
182
+ output += f"""
183
+ ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
184
+ 🌌 FINAL VERDICT
185
+ ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
186
+
187
+ {verdict}
188
+
189
+ ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
190
+ """
191
+ return output
192
+
193
+
194
+ def build_explanation(name, star_type, radius, mass, temp, flux,
195
+ period, gravity, au, star):
196
+ hz_mid = (star["hz_min"] + star["hz_max"]) / 2
197
+ in_hz = "yaşanabilir bölge içinde" if star["hz_min"] <= au <= star["hz_max"] \
198
+ else "yaşanabilir bölge dışında"
199
+
200
+ return (
201
+ f"{name}, bir {star_type} tipi yıldızın yörüngesinde, "
202
+ f"yaklaşık {au:.2f} AU uzaklıkta ({in_hz}) yer almaktadır. "
203
+ f"Dünya'nın {radius:.2f} katı yarıçapı ve {mass:.2f} katı kütlesiyle "
204
+ f"yüzey yerçekimi ~{gravity:.2f}g olarak hesaplanmıştır. "
205
+ f"\n\n"
206
+ f"Yüzey sıcaklığı {temp} K ({temp - 273:.0f}°C), "
207
+ f"sıvı su koridoru (273–373 K) ile karşılaştırıldığında "
208
+ f"{'bu aralık içindedir' if 273 <= temp <= 373 else 'bu aralığın dışındadır'}. "
209
+ f"Yıldız akısı {flux:.2f} S⊕ olup Dünya referansına "
210
+ f"({'yakın' if 0.7 <= flux <= 1.3 else 'görece uzak'}) düşmektedir. "
211
+ f"\n\n"
212
+ f"{star_type} tipi yıldızın tahmini ömrü ~{star['lifespan_gyr']:.0f} milyar yıldır; "
213
+ f"{'bu, karmaşık yaşam evrimine yeterli zamanı temsil eder' if star['lifespan_gyr'] >= 4 else 'bu süre karmaşık yaşamın evrimleşmesi için yetersiz olabilir'}. "
214
+ f"Orbital periyot {period:.1f} gün; "
215
+ f"{'tidal kilitlenme olasılığı düşük' if period > 20 else 'kısa periyot tidal kilitlenmeye işaret edebilir'}."
216
+ )
217
+
218
+
219
+ # ─────────────────────────────────────────────
220
+ # GRADIO INTERFACE
221
+ # ─────────────────────────────────────────────
222
+
223
+ EXAMPLES = [
224
+ ["Kepler-452b", 1.63, 3.0, 265, 1.10, "G", 385.0],
225
+ ["TRAPPIST-1e", 0.92, 0.77, 251, 0.38, "M", 6.1],
226
+ ["HD 40307g", 2.50, 8.0, 226, 0.40, "K", 197.8],
227
+ ["Proxima Cen b",1.08, 1.27, 234, 0.65, "M", 11.2],
228
+ ["55 Cancri f", 0.96, 0.14, 300, 0.47, "G", 260.7],
229
+ ]
230
+
231
+ CSS = """
232
+ body { font-family: 'Courier New', monospace; }
233
+ .gradio-container { max-width: 960px; margin: auto; }
234
+ #title { text-align: center; }
235
+ """
236
+
237
+ with gr.Blocks(title="🪐 Exoplanet Intelligence Engine") as demo:
238
+
239
+ gr.Markdown(
240
+ """
241
+ # 🪐 Exoplanet Intelligence Engine
242
+ ### Gezegen verilerini gir — yaşanabilirliği keşfet.
243
+ > *Bilimsel tahmin motoru · Gerçek NASA verisi içermez · Fizik tabanlı sezgisel model*
244
+ """,
245
+ elem_id="title"
246
+ )
247
+
248
+ with gr.Row():
249
+ with gr.Column(scale=1):
250
+ planet_name = gr.Textbox(label="🏷️ Gezegen Adı", placeholder="ör. Kepler-452b", value="MyPlanet-X")
251
+ radius_earth = gr.Slider( label="📏 Yarıçap (R⊕)", minimum=0.1, maximum=15.0, step=0.01, value=1.0)
252
+ mass_earth = gr.Slider( label="⚖️ Kütle (M⊕)", minimum=0.01, maximum=30.0, step=0.01, value=1.0)
253
+ temperature_k = gr.Slider( label="🌡️ Yüzey Sıcaklığı (K)",minimum=50, maximum=800, step=1, value=288)
254
+ stellar_flux = gr.Slider( label="☀️ Yıldız Akısı (S⊕)", minimum=0.01, maximum=10.0, step=0.01, value=1.0)
255
+ star_type = gr.Dropdown(label="⭐ Yıldız Tipi",
256
+ choices=["O","B","A","F","G","K","M"],
257
+ value="G")
258
+ orbital_period = gr.Slider( label="🔄 Orbital Periyot (gün)", minimum=1, maximum=1000, step=0.1, value=365.0)
259
+ analyze_btn = gr.Button("🔭 ANALİZ ET", variant="primary")
260
+
261
+ with gr.Column(scale=2):
262
+ output_box = gr.Textbox(
263
+ label="📋 Analiz Raporu",
264
+ lines=38,
265
+ max_lines=60,
266
+ )
267
+
268
+ gr.Examples(
269
+ examples=EXAMPLES,
270
+ inputs=[planet_name, radius_earth, mass_earth,
271
+ temperature_k, stellar_flux, star_type, orbital_period],
272
+ label="🌌 Hazır Örnek Gezegenler"
273
+ )
274
+
275
+ analyze_btn.click(
276
+ fn=analyze_planet,
277
+ inputs=[planet_name, radius_earth, mass_earth,
278
+ temperature_k, stellar_flux, star_type, orbital_period],
279
+ outputs=output_box
280
+ )
281
+
282
+ gr.Markdown(
283
+ """
284
+ ---
285
+ **Model Notları:** Yerçekimi `g = M/R²` yaklaşımı kullanır.
286
+ Yaşanabilir bölge sınırları yıldız tipine göre değişir.
287
+ Radyasyon riski yıldız sınıfından türetilir.
288
+ Hayat olasılığı, habitability skoru ve yıldız ömrünün fonksiyonudur.
289
+ """
290
+ )
291
+
292
+
293
+ if __name__ == "__main__":
294
+ demo.launch(css=CSS)