mirror of
				https://github.com/meta-llama/llama-stack.git
				synced 2025-10-24 16:57:21 +00:00 
			
		
		
		
	
		
			Some checks failed
		
		
	
	SqlStore Integration Tests / test-postgres (3.13) (push) Failing after 2s
				
			Integration Tests / discover-tests (push) Successful in 2s
				
			Vector IO Integration Tests / test-matrix (3.12, inline::milvus) (push) Failing after 17s
				
			Integration Auth Tests / test-matrix (oauth2_token) (push) Failing after 19s
				
			Python Package Build Test / build (3.12) (push) Failing after 14s
				
			Test Llama Stack Build / build-custom-container-distribution (push) Failing after 14s
				
			Vector IO Integration Tests / test-matrix (3.12, remote::pgvector) (push) Failing after 15s
				
			SqlStore Integration Tests / test-postgres (3.12) (push) Failing after 20s
				
			Unit Tests / unit-tests (3.13) (push) Failing after 15s
				
			Test Llama Stack Build / generate-matrix (push) Successful in 16s
				
			Vector IO Integration Tests / test-matrix (3.13, remote::pgvector) (push) Failing after 20s
				
			Test External Providers / test-external-providers (venv) (push) Failing after 17s
				
			Update ReadTheDocs / update-readthedocs (push) Failing after 15s
				
			Test Llama Stack Build / build-single-provider (push) Failing after 21s
				
			Test Llama Stack Build / build-ubi9-container-distribution (push) Failing after 18s
				
			Unit Tests / unit-tests (3.12) (push) Failing after 22s
				
			Vector IO Integration Tests / test-matrix (3.12, inline::sqlite-vec) (push) Failing after 25s
				
			Vector IO Integration Tests / test-matrix (3.13, remote::chromadb) (push) Failing after 23s
				
			Vector IO Integration Tests / test-matrix (3.13, inline::milvus) (push) Failing after 26s
				
			Vector IO Integration Tests / test-matrix (3.13, inline::sqlite-vec) (push) Failing after 19s
				
			Vector IO Integration Tests / test-matrix (3.12, inline::faiss) (push) Failing after 28s
				
			Vector IO Integration Tests / test-matrix (3.13, inline::faiss) (push) Failing after 21s
				
			Vector IO Integration Tests / test-matrix (3.12, remote::chromadb) (push) Failing after 23s
				
			Python Package Build Test / build (3.13) (push) Failing after 44s
				
			Test Llama Stack Build / build (push) Failing after 25s
				
			Integration Tests / test-matrix (push) Failing after 46s
				
			Pre-commit / pre-commit (push) Successful in 2m24s
				
			# What does this PR do? Reorganizes the Llama stack webpage into more concise index pages, introduce more of a workflow, and reduce repetition of content. New nav structure so far based on #2637 Further discussions in https://github.com/meta-llama/llama-stack/discussions/2585 **Preview:**  You can also build a full local preview locally **Feedback** Looking for feedback on page titles and general feedback on the new structure **Follow up documentation** I plan on reducing some sections and standardizing some terminology in a follow up PR. More discussions on that in https://github.com/meta-llama/llama-stack/discussions/2585
		
			
				
	
	
	
	
		
			4.1 KiB
		
	
	
	
	
	
	
	
			
		
		
	
	
			4.1 KiB
		
	
	
	
	
	
	
	
| orphan | 
|---|
| true | 
NVIDIA NEMO
NVIDIA NEMO is a remote post training provider for Llama Stack. It provides enterprise-grade fine-tuning capabilities through NVIDIA's NeMo Customizer service.
Features
- Enterprise-grade fine-tuning capabilities
- Support for LoRA and SFT fine-tuning
- Integration with NVIDIA's NeMo Customizer service
- Support for various NVIDIA-optimized models
- Efficient training with NVIDIA hardware acceleration
Usage
To use NVIDIA NEMO in your Llama Stack project, follow these steps:
- Configure your Llama Stack project to use this provider.
- Set up your NVIDIA API credentials.
- Kick off a fine-tuning job using the Llama Stack post_training API.
Setup
You'll need to set the following environment variables:
export NVIDIA_API_KEY="your-api-key"
export NVIDIA_DATASET_NAMESPACE="default"
export NVIDIA_CUSTOMIZER_URL="your-customizer-url"
export NVIDIA_PROJECT_ID="your-project-id"
export NVIDIA_OUTPUT_MODEL_DIR="your-output-model-dir"
Run Training
You can access the provider and the supervised_fine_tune method via the post_training API:
import time
import uuid
from llama_stack_client.types import (
    post_training_supervised_fine_tune_params,
    algorithm_config_param,
)
def create_http_client():
    from llama_stack_client import LlamaStackClient
    return LlamaStackClient(base_url="http://localhost:8321")
client = create_http_client()
# Example Dataset
client.datasets.register(
    purpose="post-training/messages",
    source={
        "type": "uri",
        "uri": "huggingface://datasets/llamastack/simpleqa?split=train",
    },
    dataset_id="simpleqa",
)
training_config = post_training_supervised_fine_tune_params.TrainingConfig(
    data_config=post_training_supervised_fine_tune_params.TrainingConfigDataConfig(
        batch_size=8,  # Default batch size for NEMO
        data_format="instruct",
        dataset_id="simpleqa",
        shuffle=True,
    ),
    n_epochs=50,  # Default epochs for NEMO
    optimizer_config=post_training_supervised_fine_tune_params.TrainingConfigOptimizerConfig(
        lr=0.0001,  # Default learning rate
        weight_decay=0.01,  # NEMO-specific parameter
    ),
    # NEMO-specific parameters
    log_every_n_steps=None,
    val_check_interval=0.25,
    sequence_packing_enabled=False,
    hidden_dropout=None,
    attention_dropout=None,
    ffn_dropout=None,
)
algorithm_config = algorithm_config_param.LoraFinetuningConfig(
    alpha=16,  # Default alpha for NEMO
    type="LoRA",
)
job_uuid = f"test-job{uuid.uuid4()}"
# Example Model - must be a supported NEMO model
training_model = "meta/llama-3.1-8b-instruct"
start_time = time.time()
response = client.post_training.supervised_fine_tune(
    job_uuid=job_uuid,
    logger_config={},
    model=training_model,
    hyperparam_search_config={},
    training_config=training_config,
    algorithm_config=algorithm_config,
    checkpoint_dir="output",
)
print("Job: ", job_uuid)
# Wait for the job to complete!
while True:
    status = client.post_training.job.status(job_uuid=job_uuid)
    if not status:
        print("Job not found")
        break
    print(status)
    if status.status == "completed":
        break
    print("Waiting for job to complete...")
    time.sleep(5)
end_time = time.time()
print("Job completed in", end_time - start_time, "seconds!")
print("Artifacts:")
print(client.post_training.job.artifacts(job_uuid=job_uuid))
Supported Models
Currently supports the following models:
- meta/llama-3.1-8b-instruct
- meta/llama-3.2-1b-instruct
Supported Parameters
TrainingConfig
- n_epochs (default: 50)
- data_config
- optimizer_config
- log_every_n_steps
- val_check_interval (default: 0.25)
- sequence_packing_enabled (default: False)
- hidden_dropout (0.0-1.0)
- attention_dropout (0.0-1.0)
- ffn_dropout (0.0-1.0)
DataConfig
- dataset_id
- batch_size (default: 8)
OptimizerConfig
- lr (default: 0.0001)
- weight_decay (default: 0.01)
LoRA Config
- alpha (default: 16)
- type (must be "LoRA")
Note: Some parameters from the standard Llama Stack API are not supported and will be ignored with a warning.