Spaces:
Running
Running
Create models.py
Browse files
models.py
ADDED
@@ -0,0 +1,148 @@
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
1 |
+
hf_api_key = os.getenv("HF_API_KEY")
|
2 |
+
login(token=hf_api_key)
|
3 |
+
|
4 |
+
# Set OpenAI and Hugging Face API keys
|
5 |
+
openai.api_key = "sk-1E6ExsyFb-cdU8jPNDP1dsEq_ra_bazU-EXQZQ86pJT3BlbkFJ4zURsV0t--3qNM7A-P57NUqZIBosrL7POwzpjR5EQA"
|
6 |
+
|
7 |
+
# Initialize the Gemma model
|
8 |
+
gemma_pipe = pipeline(
|
9 |
+
"text-generation",
|
10 |
+
model="google/gemma-2-2b-it",
|
11 |
+
model_kwargs={"torch_dtype": torch.bfloat16},
|
12 |
+
device="cpu"
|
13 |
+
)
|
14 |
+
|
15 |
+
# Initialize the Bloom model
|
16 |
+
bloom_model = BloomForCausalLM.from_pretrained("bigscience/bloom-560m")
|
17 |
+
bloom_tokenizer = BloomTokenizerFast.from_pretrained("bigscience/bloom-560m")
|
18 |
+
|
19 |
+
|
20 |
+
|
21 |
+
def evaluate_with_gpt(pdf_file, job_description):
|
22 |
+
resume_text = extract_text_from_pdf(pdf_file)
|
23 |
+
|
24 |
+
keywords = "وضعیت خدمت سربازی، سن، محل سکونت، محدوده حقوق پرداختی، میزان سابقه کار مدیریتی، میزان سابقه کار مرتبط با گروه شغلی مشابه، میزان سابقه کار در صنعت، میزان تحصیلات، مهارت زبان، مهارت های نرم افزاری"
|
25 |
+
|
26 |
+
prompt = f"""
|
27 |
+
به عنوان یک تحلیلگر با تجربه سیستم ردیابی متقاضی (ATS)، نقش شما شامل ارزیابی رزومه نسبت به شرح شغل و کلمات کلیدی مشخصی است.
|
28 |
+
لطفاً رزومه فرد را با در نظر گرفتن کلمات کلیدی تعیین شده مطابقت دهید و درصد تطابق را بر اساس معیارهای کلیدی و همچنین تعداد کلمات کلیدی گمشده و منطبق محاسبه کنید.
|
29 |
+
|
30 |
+
ارزیابی را بر اساس دقیقا این کلمات کلیدی {keywords} محاسبه کن.
|
31 |
+
شرح شغل: {job_description}
|
32 |
+
رزومه: {resume_text}
|
33 |
+
|
34 |
+
من پاسخ را در یک رشته با ساختار زیر میخواهم:
|
35 |
+
{{"تطابق شرح شغل با رزومه فرد ":"%"، "تعداد کلمات کلیدی غیر منطبق ":""، "تعداد کلمات کلیدی منطبق ":""}}
|
36 |
+
"""
|
37 |
+
|
38 |
+
try:
|
39 |
+
response = openai.ChatCompletion.create(
|
40 |
+
model="gpt-4o",
|
41 |
+
messages=[
|
42 |
+
{"role": "system", "content": "You are a helpful assistant."},
|
43 |
+
{"role": "user", "content": prompt}
|
44 |
+
],
|
45 |
+
temperature=0
|
46 |
+
)
|
47 |
+
return response.choices[0].message['content']
|
48 |
+
except Exception as e:
|
49 |
+
return f"Error during resume evaluation: {e}"
|
50 |
+
|
51 |
+
def evaluate_with_gemma(pdf_file, job_description):
|
52 |
+
resume_text = extract_text_from_pdf(pdf_file)
|
53 |
+
|
54 |
+
keywords = "وضعیت خدمت سربازی، سن، محل سکونت، محدوده حقوق پرداختی، میزان سابقه کار مدیریتی، میزان سابقه کار مرتبط با گروه شغلی مشابه، میزان سابقه کار در صنعت، میزان تحصیلات، مهارت زبان، مهارت های نرم افزاری"
|
55 |
+
|
56 |
+
prompt = f"""
|
57 |
+
به عنوان یک تحلیلگر با تجربه سیستم ردیابی متقاضی (ATS)، نقش شما شامل ارزیابی رزومه نسبت به شرح شغل و کلمات کلیدی مشخصی است.
|
58 |
+
لطفاً رزومه فرد را با در نظر گرفتن کلمات کلیدی تعیین شده مطابقت دهید و درصد تطابق را بر اساس معیارهای کلیدی و همچنین تعداد کلمات کلیدی گمشده و منطبق محاسبه کنید.
|
59 |
+
|
60 |
+
ارزیابی را بر اساس دقیقا این کلمات کلیدی {keywords} محاسبه کن.
|
61 |
+
شرح شغل: {job_description}
|
62 |
+
رزومه: {resume_text}
|
63 |
+
|
64 |
+
من پاسخ را در یک رشته با ساختار زیر میخواهم:
|
65 |
+
{{"تطابق شرح شغل با رزومه فرد ":"%"، "تعداد کلمات کلیدی غیر منطبق ":""، "تعداد کلمات کلیدی منطبق ":""}}
|
66 |
+
"""
|
67 |
+
|
68 |
+
outputs = gemma_pipe(prompt, max_new_tokens=256)
|
69 |
+
return outputs[0]["generated_text"].strip()
|
70 |
+
|
71 |
+
def evaluate_with_bloom(pdf_file, job_description):
|
72 |
+
resume_text = extract_text_from_pdf(pdf_file)
|
73 |
+
|
74 |
+
keywords = "وضعیت خدمت سربازی، سن، محل سکونت، محدوده حقوق پرداختی، میزان سابقه کار مدیریتی، میزان سابقه کار مرتبط با گروه شغلی مشابه، میزان سابقه کار در صنعت، میزان تحصیلات، مهارت زبان، مهارت های نرم افزاری"
|
75 |
+
|
76 |
+
prompt = f"""
|
77 |
+
به عنوان یک تحلیلگر با تجربه سیستم ردیابی متقاضی (ATS)، نقش شما شامل ارزیابی رزومه نسبت به شرح شغل و کلمات کلیدی مشخصی است.
|
78 |
+
لطفاً رزومه فرد را با در نظر گرفتن کلمات کلیدی تعیین شده مطابقت دهید و درصد تطابق را بر اساس معیارهای کلیدی و همچنین تعداد کلمات کلیدی گ��شده و منطبق محاسبه کنید.
|
79 |
+
|
80 |
+
ارزیابی را بر اساس دقیقا این کلمات کلیدی {keywords} محاسبه کن.
|
81 |
+
شرح شغل: {job_description}
|
82 |
+
رزومه: {resume_text}"""
|
83 |
+
|
84 |
+
inputs = bloom_tokenizer(prompt, return_tensors="pt")
|
85 |
+
outputs = bloom_model.generate(inputs["input_ids"], max_length=2000)
|
86 |
+
return bloom_tokenizer.decode(outputs[0], skip_special_tokens=True).strip()
|
87 |
+
|
88 |
+
def evaluate_with_jabir(pdf_file, job_description):
|
89 |
+
resume_text = extract_text_from_pdf(pdf_file)
|
90 |
+
|
91 |
+
keywords = "وضعیت خدمت سربازی، سن، محل سکونت، محدوده حقوق پرداختی، میزان سابقه کار مدیریتی، میزان سابقه کار مرتبط با گروه شغلی مشابه، میزان سابقه کار در صنعت، میزان تحصیلات، مهارت زبان، مهارت های نرم افزاری"
|
92 |
+
|
93 |
+
prompt = f"""
|
94 |
+
به عنوان یک تحلیلگر با تجربه سیستم ردیابی متقاضی (ATS)، نقش شما شامل ارزیابی رزومه نسبت به شرح شغل و کلمات کلیدی مشخصی است.
|
95 |
+
لطفاً رزومه فرد را با در نظر گرفتن کلمات کلیدی تعیین شده مطابقت دهید و درصد تطابق را بر اساس معیارهای کلیدی و همچنین تعداد کلمات کلیدی گمشده و منطبق محاسبه کنید.
|
96 |
+
|
97 |
+
ارزیابی را بر اساس دقیقا این کلمات کلیدی {keywords} محاسبه کن.
|
98 |
+
شرح شغل: {job_description}
|
99 |
+
رزومه: {resume_text}"""
|
100 |
+
|
101 |
+
base_url = "https://api.jabirproject.org/generate"
|
102 |
+
headers = {"apikey": "7471142a-deb4-4a70-8ee3-6603e21bcc1d"}
|
103 |
+
data = {
|
104 |
+
"messages": [{"role": "user", "content": prompt}]
|
105 |
+
}
|
106 |
+
|
107 |
+
response = requests.post(base_url, headers=headers, json=data)
|
108 |
+
|
109 |
+
if response.ok:
|
110 |
+
return response.json()
|
111 |
+
else:
|
112 |
+
return f"Error: {response.status_code}, {response.text}"
|
113 |
+
|
114 |
+
|
115 |
+
|
116 |
+
|
117 |
+
|
118 |
+
|
119 |
+
|
120 |
+
model_id = "meta-llama/Meta-Llama-3.1-8B-Instruct"
|
121 |
+
|
122 |
+
pipeline = transformers.pipeline(
|
123 |
+
"text-generation",
|
124 |
+
model=model_id,
|
125 |
+
model_kwargs={"torch_dtype": torch.bfloat16},
|
126 |
+
device_map="auto",
|
127 |
+
)
|
128 |
+
|
129 |
+
def evaluate_with_llama(resume_text, job_description):
|
130 |
+
keywords = "وضعیت خدمت سربازی، سن، محل سکونت، محدوده حقوق پرداختی، میزان سابقه کار مدیریتی، میزان سابقه کار مرتبط با گروه شغلی مشابه، میزان سابقه کار در صنعت، میزان تحصیلات، مهارت زبان، مهارت های نرم افزاری"
|
131 |
+
|
132 |
+
prompt = f"""
|
133 |
+
به عنوان یک تحلیلگر با تجربه سیستم ردیابی متقاضی (ATS)، نقش شما شامل ارزیابی رزومه نسبت به شرح شغل و کلمات کلیدی مشخصی است.
|
134 |
+
لطفاً رزومه فرد را با در نظر گرفتن کلمات کلیدی تعیین شده مطابقت دهید و درصد تطابق را بر اساس معیارهای کلیدی و همچنین تعداد کلمات کلیدی گمشده و منطبق محاسبه کنید.
|
135 |
+
|
136 |
+
ارزیابی را بر اساس دقیقا این کلمات کلیدی {keywords} محاسبه کن.
|
137 |
+
شرح شغل: {job_description}
|
138 |
+
رزومه: {resume_text}
|
139 |
+
|
140 |
+
من پاسخ را در یک رشته با ساختار زیر میخواهم:
|
141 |
+
{{"تطابق شرح شغل با رزومه فرد ":"%", "تعداد کلمات کلیدی غیر منطبق ":"", "تعداد کلمات کلیدی منطبق ":""}}
|
142 |
+
"""
|
143 |
+
|
144 |
+
outputs = pipeline(
|
145 |
+
prompt,
|
146 |
+
max_new_tokens=256,
|
147 |
+
)
|
148 |
+
return outputs[0]["generated_text"]
|