File size: 14,306 Bytes
feca201
 
 
 
 
 
 
 
 
ad95c7a
feca201
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
98d4147
feca201
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
5d790f7
 
feca201
 
 
 
 
0efcb82
f02c206
0efcb82
 
01c77ff
8d3cd93
0efcb82
 
 
 
01c77ff
8d3cd93
0efcb82
 
 
f02c206
3d90220
feca201
 
 
 
 
 
 
5d790f7
feca201
 
 
3d90220
feca201
 
b0bfd3b
feca201
 
 
 
 
 
 
 
 
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
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
import os

import pandas as pd
from sklearn.ensemble import RandomForestClassifier
from sklearn.model_selection import train_test_split

import gradio as gr

current_dir = os.path.dirname(os.path.realpath(__file__))
data = pd.read_csv(os.path.join(current_dir, "datav4.csv"))




X_all = data.drop(["targets"], axis=1)
y_all = data["targets"]

num_test = 0.20
X_train, X_test, y_train, y_test = train_test_split(
    X_all, y_all, test_size=num_test, random_state=23
)

clf = RandomForestClassifier()
clf.fit(X_train, y_train)
from joblib import dump, load


js = """
function createGradioAnimation() {

	


    var containerlog = document.createElement('div');
    containerlog.id = 'gradio-animation';
    containerlog.style.fontSize = '2em';
    containerlog.style.fontWeight = 'bold';
    containerlog.style.textAlign = 'center';
    containerlog.style.marginBottom = '50px';
    var logo = document.createElement('img');
    logo.src = 'https://data2innov.fr/build/img/data2innov_logo.svg'; // Replace with your logo URL
    logo.style.width = '200px'; // Adjust the size of the logo
    containerlog.appendChild(logo);

    var textElement = document.createElement('span');
   // Ajouter le texte entre les deux images
     textElement.textContent = "L'IA au service de l'implantologie   Pr. Zoubeir TOURKI "; // Remplacez par votre texte
   containerlog.appendChild(textElement);
    var logo2 = document.createElement('img');
    logo2.src=''
    logo2.style.width = '100px'; // Adjust the size of the logo
    containerlog.appendChild(logo2);
    containerlog.style.display = 'flex';
    containerlog.style.flexWrap = 'wrap';
    containerlog.style.justifyContent = 'space-between';

    var container = document.createElement('div');
    container.id = 'gradio-animation';
    container.style.fontSize = '2em';
    container.style.fontWeight = 'bold';
    container.style.textAlign = 'center';
    container.style.marginBottom = '50px';

    var text = 'Cette application est realisée dans le cadre du congrés ATMO 1-2  mars 2024 à Monastir';
    for (var i = 0; i < text.length; i++) {
        (function(i){
            setTimeout(function(){
                var letter = document.createElement('span');
                letter.style.opacity = '0';
                 letter.style.color='red'
                letter.style.transition = 'opacity 0.5s';
                letter.innerText = text[i];

                container.appendChild(letter);

                setTimeout(function() {
                    letter.style.opacity = '1';
                }, 50);
            }, i * 250);
        })(i);
    }

    var gradioContainerlog = document.querySelector('.gradio-container');

    gradioContainerlog.insertBefore(containerlog, gradioContainerlog.firstChild);
    var gradioContainer = document.querySelector('.gradio-container');
    gradioContainer.insertBefore(container, gradioContainer.firstChild);

    return 'Animation created';
}
"""


#clf = load('filename.model') 
#predictions = clf.predict(X_test)


def predict_survival(densites,  diametres):
   
    df = pd.DataFrame.from_dict(
        {
            "densites": [densites],
            "diametres": [diametres]
        }
    )
    if 300> densites or densites>1200 :
    	 gr.Info("La densité doit être entre 300 et 1200 HU'")
    	 return None
    if 3> diametres or diametres>6 :
    	 gr.Info("le diametre doit être entre 3 et 6 mm")
    	 return None
    pred = clf.predict_proba(df)[0]

    html=0
    if (pred[0]<pred[1]):
        html = (
            "<div style='max-width:100%; color:green; font-size: 20px; background-color:white; text-align:center; max-height:360px; overflow:auto'>"
            + "<br> <br> Vous pouvez poser l'implant (précison : "+str(int(pred[1]*100))+"%)<br> <br>"
            + "</div>"
        )
    else:
        html = (
            "<div style='max-width:100%; color:red; font-size: 20px; background-color:white; text-align:center; max-height:360px; overflow:auto'>"
            + "<br> <br> Vous ne pouvez pas poser l'implant (précison : "+str(int(pred[0]*100))+"%)<br> <br>"
            + "</div>"
        )

    json_pred={"No": float(pred[0]), "Yes": float(pred[1])}
    return html


demo = gr.Interface(
    predict_survival,
    [
       
        
        gr.Number(label="Densité 'entre 300 et 1200 HU'"),
        gr.Number(label="Diametre 'entre 3 et 6 mm'")
        
    ],
    ["html"],
    examples=[
        [700, 5],
        [1200, 3],
        [311, 5.2]
    ],
    live=False,
    js=js,
    submit_btn="Prédire"
)

if __name__ == "__main__":
    demo.launch(share=True)