|
|
|
|
|
!pip install git+https://github.com/huggingface/transformers.git |
|
|
!pip install sentencepiece |
|
|
!pip install peft |
|
|
!pip install accelerate |
|
|
!pip install bitsandbytes |
|
|
import torch |
|
|
from peft import PeftModel |
|
|
import transformers |
|
|
|
|
|
from transformers import LlamaTokenizer, LlamaForCausalLM, GenerationConfig |
|
|
|
|
|
tokenizer = LlamaTokenizer.from_pretrained("decapoda-research/llama-7b-hf") |
|
|
device = torch.device("cuda:0" if torch.cuda.is_available() else "cpu") |
|
|
print(device) |
|
|
model = LlamaForCausalLM.from_pretrained( |
|
|
"decapoda-research/llama-7b-hf", |
|
|
load_in_8bit=True, |
|
|
torch_dtype=torch.float16, |
|
|
device_map="auto", |
|
|
offload_folder = "." |
|
|
) |
|
|
|
|
|
model = PeftModel.from_pretrained( |
|
|
model, |
|
|
"tloen/alpaca-lora-7b", |
|
|
torch_dtype=torch.float16, |
|
|
device_map="auto", |
|
|
load_in_8bit = True, |
|
|
offload_folder="." |
|
|
) |
|
|
|
|
|
def generate_prompt(instruction, input=None): |
|
|
if input: |
|
|
return f"""Below is an instruction that describes a task, paired with an input that provides further context. Write a response that appropriately completes the request. |
|
|
|
|
|
### Instruction: |
|
|
{instruction} |
|
|
|
|
|
### Input: |
|
|
{input} |
|
|
|
|
|
### Response:""" |
|
|
else: |
|
|
return f"""Below is an instruction that describes a task. Write a response that appropriately completes the request. |
|
|
|
|
|
### Instruction: |
|
|
{instruction} |
|
|
|
|
|
### Response:""" |
|
|
|
|
|
|
|
|
model.eval() |
|
|
|
|
|
|
|
|
def evaluate( |
|
|
instruction, |
|
|
input=None, |
|
|
temperature=0.1, |
|
|
top_p=0.75, |
|
|
top_k=40, |
|
|
num_beams=4, |
|
|
**kwargs, |
|
|
): |
|
|
prompt = generate_prompt(instruction, input) |
|
|
inputs = tokenizer(prompt, return_tensors="pt") |
|
|
input_ids = inputs["input_ids"].to(device) |
|
|
generation_config = GenerationConfig( |
|
|
temperature=temperature, |
|
|
top_p=top_p, |
|
|
top_k=top_k, |
|
|
num_beams=num_beams, |
|
|
**kwargs, |
|
|
) |
|
|
with torch.no_grad(): |
|
|
generation_output = model.generate( |
|
|
input_ids=input_ids, |
|
|
generation_config=generation_config, |
|
|
return_dict_in_generate=True, |
|
|
output_scores=True, |
|
|
max_new_tokens=2048, |
|
|
) |
|
|
s = generation_output.sequences[0] |
|
|
output = tokenizer.decode(s) |
|
|
return output.split("### Response:")[1].strip() |
|
|
input = """RESEARCH REPORT NO. 1037027Final Clinical Study Report -NV25118: A Randomized, Multicentre, Single Blinded, Parallel Study of the Safety of 100 mg and 200 mg Oseltamivir Administered Intravenously for the Treatment of Influenza in Patients Aged > 13 Years. Report No. 1037027. June 3, 2013 Study Sponsor(s):Dr F Hoffman La-Roche LtdStudy Dates:First patient screened: Jan 15, 2010 Last patient visit: Sept 14, 2012Trial Phase:II/IIIIndication:InfluenzaName of Principal Investigator Thomas MathewSponsor's Signatory: Personnel Responsible for Clinical and Statistical Analyses: Clinical analysis:John ThomasSafety analysis:William RichardStatistical analysis:Charles DanielPharmacokinetic analysis:Robert DavidGCP Compliance: This study was conducted in accordance with the principles of GCP""" |
|
|
instruction = "Extract Names, Diseases, Dates from below text:" |
|
|
|
|
|
print("Response:", evaluate(instruction,input)) |