File size: 2,014 Bytes
64cc025
98d78ef
64cc025
98d78ef
 
 
88d231a
 
64cc025
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
98d78ef
 
 
64cc025
 
 
 
88d231a
64cc025
 
 
 
 
 
 
 
 
 
 
98d78ef
 
 
64cc025
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
from flask import Flask, request, jsonify
from twilio.twiml.messaging_response import MessagingResponse
from huggingface_hub import InferenceClient

app = Flask(__name__)

print("\nHello welcome to Sema AI\n", flush=True)

# Initialize InferenceClient
client = InferenceClient("mistralai/Mistral-7B-Instruct-v0.1")
conversation_history = {}

def format_prompt(message, history):
    prompt = "<s>"
    for user_prompt, bot_response in history:
        prompt += f"[INST] {user_prompt} [/INST]"
        prompt += f" {bot_response}</s> "
    prompt += f"[INST] {message} [/INST]"
    return prompt

def generate(prompt, history, temperature=0.9, max_new_tokens=100, top_p=0.95, repetition_penalty=1.0):
    formatted_prompt = format_prompt(prompt, history)

    generate_kwargs = dict(
        temperature=temperature,
        max_new_tokens=max_new_tokens,
        top_p=top_p,
        repetition_penalty=repetition_penalty,
        do_sample=True,
        seed=42,
    )

    response = client.text_generation(
        formatted_prompt,
        **generate_kwargs,
        stream=True,
        details=True,
        return_full_text=False
    )

    output = ""
    for token in response:
        if hasattr(token, 'token') and hasattr(token.token, 'text'):
            output += token.token.text

    return output

@app.route("/sms", methods=['GET', 'POST'])
def sms():
    try:
        resp = MessagingResponse()
        sender_number = request.form['From']
        inb_msg = request.form['Body'].strip()
        print(inb_msg, flush=True)

        history = conversation_history.get(sender_number, [])
        output = generate(inb_msg, history)
        history.append((inb_msg, output))
        conversation_history[sender_number] = history

        resp.message(output)
    except Exception as e:
        print(f"Error processing SMS: {str(e)}")
        resp.message("Sorry, an error occurred. Please try again later.")
    
    return str(resp)

if __name__ == "__main__":
    app.run(debug=True, port=5000)