1. Overview

A Korean text-embedding model for the BC Card domain, built by LoRA fine-tuning Qwen/Qwen3-Embedding-0.6B on BC Card in-domain data (personal / merchant / corporate / VIP). It is intended as the retriever (bi-encoder) stage of a BC Card RAG pipeline.

On a held-out in-domain test set it improves NDCG@10 by +8.2% and Accuracy@1 by +11.3% over the base model.

1.1. TL;DR

  • Base model: Qwen/Qwen3-Embedding-0.6B — 28 layers, hidden 1024, last-token pooling, instruction-aware
  • Domain / Language: Finance (BC Card — personal / merchant / corporate / VIP) / Korean
  • Task: Query-document retrieval (QA search, document similarity), RAG retriever
  • Method: PEFT (LoRA) + Multiple Negatives Ranking (contrastive)
  • Format: merged standalone (LoRA fused into base; loads with sentence-transformers, no peft)
  • Embedding dimension: 1024 · Max sequence length: 1024 · Similarity: cosine (outputs are L2-normalized)
  • Intended use
    • In-house BC Card-domain RAG retriever (Top-K candidate retrieval)
    • QA search, document-similarity scoring

1.2. Usage

The model was trained with an instruction prefix on the query side only (documents get no instruction). Inject the same instruction at inference so query/document encoding matches training.

from sentence_transformers import SentenceTransformer

model = SentenceTransformer("BCCard/MoAI-Embedding-0.6B")

# Query-side instruction (identical to training) - prepend to every query at inference time
QUERY_INSTRUCTION = "Instruct: Given a web search query, retrieve relevant passages that answer the query\nQuery: "

queries = ["BC카드 연회비는 어떻게 되나요?"]
documents = [
    "BC카드 연회비는 카드 종류와 혜택 구성에 따라 다르게 책정됩니다 ...",
    "바로카드 연회비는 국내 전용과 해외 겸용 여부에 따라 차등 부과됩니다 ...",
    "전월 실적 등 조건을 충족하면 다음 해 연회비가 면제되는 카드도 있습니다 ...",
    "카드 분실 신고는 고객센터 또는 앱에서 즉시 가능합니다 ...",
    ...
]

# Queries: inject the instruction · Documents: no instruction
q_emb = model.encode(queries, prompt=QUERY_INSTRUCTION)
d_emb = model.encode(documents)

scores = model.similarity(q_emb, d_emb)   # cosine; rank documents by score
print(scores)

The instruction is also stored in the model config, so model.encode(queries, prompt_name="query") is equivalent to passing prompt=QUERY_INSTRUCTION explicitly. Documents use no prompt (prompt_name="document" is an empty string).

  • Query prompt (instruction): Instruct: Given a web search query, retrieve relevant passages that answer the query\nQuery:
  • Document prompt: none

1.3. Training Data

Dataset Role Size
BCAI-Finance-Kor-Embedding-Triplet Training (anchor / positive / negative) 43,394 triplets (train)
BCAI-Finance-Kor-Embedding-Pair Corpus pool / evaluation 36,281 unique chunks
  • Sources: BC Card financial QA (BCAI) + website crawl + synthetic data (chunking + multi-query generation)
  • Triplets are constructed via hard-negative mining over the unified corpus.

1.4. Training Procedure

Item Value
Method LoRA (PEFT)
LoRA r=64, alpha=128, dropout=0.05, targets = q,k,v,o,gate,up,down_proj
Loss CachedMultipleNegativesRankingLoss (in-batch negatives)
Batch per-device 256 (DDP) → 511 in-batch negatives per rank
LR / scheduler 1e-4 / cosine, warmup_ratio 0.1, weight_decay 0.01
Epochs 3, early stopping — best checkpoint selected by validation NDCG@10
Precision bf16, gradient checkpointing
Hardware 6× NVIDIA L40S (DDP)

2. Evaluation

2.1. Setup

  • Queries: 1,000 (held-out test split) · Corpus: 36,281 unique chunks
  • Protocol: binary-relevance information retrieval; the same evaluator used during training
  • Metrics: NDCG@10 (primary), MRR@10, Recall@{1,10}, Accuracy@1, MAP@10
  • Models compared: base (Qwen3-Embedding-0.6B, no fine-tuning) vs. v1 (r32 / lr2e-4 / 4ep) vs. v2 (r64 / lr1e-4 / 3ep, released)

2.2. Training

Training curves - loss, learning rate, validation NDCG@10 (WandB)

Trained for 3 epochs (early-stopped) with a cosine schedule; training loss decreases steadily while validation NDCG@10 climbs early and plateaus, and the best checkpoint is selected at the peak. Curves (loss / learning rate / validation NDCG@10) are logged to Weights & Biases.


2.3. In-domain Retrieval Benchmark

Test-set retrieval metrics - base vs v1 vs v2
Test-set retrieval metrics comparison (per metric)
Metric base (Qwen3-0.6B) v1 (r32/2e-4/4ep) v2 (r64/1e-4/3ep) v2 Δ vs base
NDCG@10 0.6186 0.6665 0.6695 +0.051 (+8.2%)
MRR@10 0.6449 0.6993 0.7060 +0.061 (+9.5%)
Recall@10 0.7046 0.7512 0.7508 +0.046 (+6.6%)
Recall@1 0.4730 0.5221 0.5293 +0.056 (+11.9%)
Accuracy@1 0.5560 0.6080 0.6190 +0.063 (+11.3%)
MAP@10 0.5652 0.6131 0.6171 +0.052 (+9.2%)

v2 is the released model (best across all metrics; Recall@10 is on par with v1). Fine-tuning lifts in-domain retrieval by roughly +10% over the base model, with the largest gains on top-rank precision (Accuracy@1, Recall@1).


2.4. Limitations

  • Domain-specific — tuned for BC Card Korean financial text; out-of-domain or non-Korean performance is not guaranteed.
  • Re-ranking recommended — as a 0.6B bi-encoder, it favors recall/throughput over fine-grained precision.
    • Recommended pipeline: Bi-Encoder (this model) Top-K → Cross-Encoder re-ranking
  • Sequence length — inputs are truncated at 1,024 tokens; content past that limit is not encoded, so very long documents should be chunked before indexing.
  • Exact-value matching — fine-grained numeric/tabular facts (fees, rates, dates, terms) are not reliably distinguished by dense similarity alone; pair with lexical (BM25) retrieval or a re-ranker when exactness matters.
  • Retrieval only — this is an embedding model, not a generator; it ranks passages and does not produce answers.
  • Synthetic data influence — part of the training set is LLM-synthesized (chunking + multi-query), which may carry the generator's stylistic/coverage biases.

3. Future Work

  • Data quality improvement & re-training
    • Human-annotation labeling
    • More rigorous hard-negative mining (iterative, mined with this model)
    • Broader/higher-quality data (incl. general financial corpora)
  • System-level
    • Cross-Encoder re-ranker for precision
    • HyDE / dynamic instruction injection at query time

4. Meta Info

4.1. Citation

@misc{bccard2026moaiembedding,
  title        = {MoAI-Embedding-0.6B: A BC Card-Domain Korean Text Embedding Model},
  author       = {BC Card AX Team},
  year         = {2026},
  howpublished = {https://huggingface.co/BCCard/MoAI-Embedding-0.6B},
  note         = {LoRA fine-tune of Qwen3-Embedding-0.6B for BC Card-domain Korean retrieval}
}

4.2. See Also


Downloads last month
59
Safetensors
Model size
0.6B params
Tensor type
BF16
·
Inference Providers NEW
This model isn't deployed by any Inference Provider. 🙋 Ask for provider support

Model tree for BCCard/MoAI-Embedding-0.6B

Adapter
(11)
this model
Adapters
1 model

Datasets used to train BCCard/MoAI-Embedding-0.6B