b-mc2/sql-create-context
Viewer β’ Updated β’ 78.6k β’ 3.75k β’ 497
How to use Shizu0n/phi3-mini-sql-generator with PEFT:
from peft import PeftModel
from transformers import AutoModelForCausalLM
base_model = AutoModelForCausalLM.from_pretrained("microsoft/Phi-3-mini-4k-instruct")
model = PeftModel.from_pretrained(base_model, "Shizu0n/phi3-mini-sql-generator")Fine-tuned version of Phi-3-mini-4k-instruct for natural language β SQL generation using QLoRA on a T4 GPU (Google Colab, ~20 min).
Evaluated on 200 held-out examples from b-mc2/sql-create-context.
| Model | Exact Match |
|---|---|
| Phi-3-mini-4k-instruct (base) | 2.0% |
| This adapter (fine-tuned) | 73.5% |
Exact match: normalized SQL comparison (lowercase, strip whitespace/semicolons).
| Parameter | Value |
|---|---|
| Rank (r) | 16 |
| Alpha | 32 |
| Dropout | 0.05 |
| Target modules | qkv_proj, o_proj, gate_up_proj, down_proj |
| Quantization | 4-bit NF4 (QLoRA) |
from transformers import AutoModelForCausalLM, AutoTokenizer
from peft import PeftModel
import torch
tokenizer = AutoTokenizer.from_pretrained(
"microsoft/Phi-3-mini-4k-instruct", trust_remote_code=True
)
base_model = AutoModelForCausalLM.from_pretrained(
"microsoft/Phi-3-mini-4k-instruct",
torch_dtype=torch.float16,
device_map="auto",
trust_remote_code=True,
attn_implementation="eager",
)
model = PeftModel.from_pretrained(base_model, "Shizu0n/phi3-mini-sql-generator")
model.eval()
prompt = (
"Given the following SQL table, write a SQL query.\n\n"
"Table: employees (id, name, department, salary)\n\n"
"Question: What is the average salary per department?\n\nSQL:"
)
inputs = tokenizer(prompt, return_tensors="pt").to(model.device)
with torch.inference_mode():
outputs = model.generate(**inputs, max_new_tokens=100, do_sample=False)
prompt_len = inputs["input_ids"].shape[-1]
print(tokenizer.decode(outputs[0][prompt_len:], skip_special_tokens=True))
The LoRA adapter weights have been merged into a standalone model at Shizu0n/phi3-mini-sql-generator-merged β no PEFT dependency required for inference.
Base model
microsoft/Phi-3-mini-4k-instruct