File size: 3,132 Bytes
ac2c6e9
 
 
e865ed1
 
 
ac2c6e9
e865ed1
 
 
 
ac2c6e9
e865ed1
 
 
ac2c6e9
e865ed1
 
 
 
ac2c6e9
 
e865ed1
ac2c6e9
 
e865ed1
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
ac2c6e9
e865ed1
 
 
ac2c6e9
e865ed1
 
 
 
 
 
a0e05b2
e865ed1
 
 
 
 
 
 
 
 
 
ac2c6e9
e865ed1
 
 
ac2c6e9
 
e865ed1
 
 
 
 
 
 
a0e05b2
ac2c6e9
e865ed1
ac2c6e9
 
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
import os
import time
import zipfile
import gradio as gr
import subprocess
import threading

# Paths
OUTPUT_DIR = "train_output"
ZIP_FILE = "python_ai_trained_model.zip"
LOG_FILE = "train_log.txt"

# Shared states
start_time = None
end_time = None

# Function: Zip the trained model
def zip_trained_model():
    with zipfile.ZipFile(ZIP_FILE, 'w', zipfile.ZIP_DEFLATED) as zipf:
        for root, _, files in os.walk(OUTPUT_DIR):
            for file in files:
                filepath = os.path.join(root, file)
                arcname = os.path.relpath(filepath, OUTPUT_DIR)
                zipf.write(filepath, arcname)

# Function: Tail the logs from training
def tail_logs():
    if not os.path.exists(LOG_FILE):
        return ""
    with open(LOG_FILE, 'r') as f:
        lines = f.readlines()[-20:]  # last 20 lines
        return ''.join(lines)

# Background training function
def run_training(status_box, time_box, download_file, model_size_box, log_box):
    global start_time, end_time

    start_time = time.time()
    status_box.value = "πŸš€ Training started... Please wait. This can take 30–90+ minutes."
    time_box.value = "Training in progress..."
    log_box.value = ""

    # Run training and redirect stdout/stderr to log file
    with open(LOG_FILE, "w") as log:
        process = subprocess.Popen(["python", "train.py"], stdout=log, stderr=log)
        while process.poll() is None:
            log_box.value = tail_logs()
            time.sleep(5)

    end_time = time.time()
    elapsed = round(end_time - start_time, 2)
    time_box.value = f"βœ… Training completed in {elapsed // 60:.0f} min {elapsed % 60:.0f} sec."

    status_box.value = "πŸ”„ Compressing trained model..."
    zip_trained_model()

    size_mb = round(os.path.getsize(ZIP_FILE) / (1024 * 1024), 2)
    model_size_box.value = f"πŸ“¦ Model Size: {size_mb} MB"

    download_file.value = ZIP_FILE
    download_file.visible = True
    status_box.value = "βœ… Done! You can now download your trained model."

# Trigger button click
def start_training(status_box, time_box, download_file, model_size_box, log_box):
    thread = threading.Thread(target=run_training, args=(status_box, time_box, download_file, model_size_box, log_box))
    thread.start()
    return "Training process has started..."

# Gradio UI
with gr.Blocks() as demo:
    gr.Markdown("## 🧠 Python AI Trainer (StarCoder 7B)")
    gr.Markdown("Train a custom Python AI that can write, fix, and explain Python code.")

    with gr.Row():
        train_btn = gr.Button("πŸš€ Start Training")
        status_box = gr.Textbox(label="Status", value="Ready", interactive=False)
    
    with gr.Row():
        time_box = gr.Textbox(label="Training Time", interactive=False)
        model_size_box = gr.Textbox(label="Final Model Size", interactive=False)

    log_box = gr.Textbox(label="Live Training Logs", lines=20, interactive=False)
    download_file = gr.File(label="πŸ“₯ Download Trained Model (.zip)", visible=False)

    train_btn.click(fn=start_training, inputs=[status_box, time_box, download_file, model_size_box, log_box], outputs=[status_box])

demo.launch()