File size: 4,291 Bytes
dd02c0c
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
b2dc742
821c973
b2dc742
 
 
dd02c0c
821c973
b2dc742
 
821c973
b2dc742
 
 
 
44f51ce
b2dc742
dd02c0c
 
 
 
 
 
 
b2dc742
 
dd02c0c
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
b2dc742
dd02c0c
b2dc742
 
 
dd02c0c
 
 
 
 
b2dc742
 
 
dd02c0c
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
# # import dependencies
# import gradio as gr
# from openai import OpenAI
# import os
# import re

# # define the openai key
# api_key = "sk-proj-UCoZZMs4MyfyHwXdHjT8T3BlbkFJjYkSZyPfIPNqXfXwoekm"

# # make an instance of the openai client
# client = OpenAI(api_key = api_key)


# # finetuned model instance
# finetuned_model = "ft:gpt-3.5-turbo-0125:personal::9qGC8cwZ"

# # function to humanize the text
# def humanize_text(AI_text):
#   """Humanizes the provided AI text using the fine-tuned model."""
#   response = completion = client.chat.completions.create(
#   model=finetuned_model,
#   temperature = 0.85,
#   messages=[
#     {"role": "system", "content": """
#     You are a text humanizer.
#     You humanize AI generated text.
#     The text must appear like humanly written.
#     THE INPUT AND THE OUTPUT TEXT SHOULD HAVE THE SAME FORMAT.
#     THE HEADINGS AND THE BULLETS IN THE INPUT SHOULD REMAIN IN PLACE"""},
#     {"role": "user", "content": f"THE LANGUAGE OF THE INPUT AND THE OUTPUT MUST BE SAME. THE SENTENCES SHOULD NOT BE SHORT LENGTH - THEY SHOULD BE SAME AS IN THE INPUT. ALSO THE PARAGRAPHS SHOULD NOT BE SHORT EITHER - PARAGRAPHS MUST HAVE THE SAME LENGTH"},
#     {"role": "user", "content": f"Humanize the text. Keep the output format i.e. the bullets and the headings as it is and dont use the list of words that are not permissible. \nTEXT: {AI_text}"}
#   ]
#   )

#   humanized_text = response.choices[0].message.content.strip()

#   return humanized_text


# # Gradio interface definition
# interface = gr.Interface(
#   fn=humanize_text,
#   inputs="textbox",
#   outputs="textbox",
#   title="AI Text Humanizer: NoaiGPT.com Demo",
#   description="Enter AI-generated text and get a human-written version.",
# )

# # Launch the Gradio app
# interface.launch(debug = True)

# import dependencies
import gradio as gr
from openai import OpenAI
import os
import re
from transformers import pipeline

# define the openai key
api_key = "sk-proj-UCoZZMs4MyfyHwXdHjT8T3BlbkFJjYkSZyPfIPNqXfXwoekm"

# make an instance of the openai client
client = OpenAI(api_key = api_key)

# finetuned model instance
finetuned_model = "ft:gpt-3.5-turbo-0125:personal::9qGC8cwZ"

# Load the AI detection model
pipe = pipeline("text-classification", model="tommyliphys/ai-detector-distilbert")

# Define the function to get predictions
def get_prediction(text):
    return pipe(text)[0]

# function to humanize the text
def humanize_text(AI_text):
    """Humanizes the provided AI text using the fine-tuned model."""
    humanized_text = AI_text
    attempts = 0
    max_attempts = 3

    while attempts < max_attempts:
        response = client.chat.completions.create(
            model=finetuned_model,
            temperature=0.85,
            messages=[
                {"role": "system", "content": """
                You are a text humanizer.
                You humanize AI generated text.
                The text must appear like humanly written.
                THE INPUT AND THE OUTPUT TEXT SHOULD HAVE THE SAME FORMAT.
                THE HEADINGS AND THE BULLETS IN THE INPUT SHOULD REMAIN IN PLACE"""},
                {"role": "user", "content": "THE LANGUAGE OF THE INPUT AND THE OUTPUT MUST BE SAME. THE SENTENCES SHOULD NOT BE SHORT LENGTH - THEY SHOULD BE SAME AS IN THE INPUT. ALSO THE PARAGRAPHS SHOULD NOT BE SHORT EITHER - PARAGRAPHS MUST HAVE THE SAME LENGTH"},
                {"role": "user", "content": f"Humanize the text. Keep the output format i.e. the bullets and the headings as it is and dont use the list of words that are not permissible. \nTEXT: {humanized_text}"}
            ]
        )

        humanized_text = response.choices[0].message.content.strip()
        
        # Check if the humanized text is still detected as AI
        prediction = get_prediction(humanized_text)
        
        if prediction['label'] != 'AI' or prediction['score'] < 0.9:
            break
        
        attempts += 1

    return humanized_text

# Gradio interface definition
interface = gr.Interface(
    fn=humanize_text,
    inputs="textbox",
    outputs="textbox",
    title="AI Text Humanizer: NoaiGPT.com Demo",
    description="Enter AI-generated text and get a human-written version.",
)

# Launch the Gradio app
interface.launch(debug=True)