KEMBAR78
Running and Fine-Tuning Open Source LLMs | PDF | Graphics Processing Unit | Program Optimization
0% found this document useful (0 votes)
62 views16 pages

Running and Fine-Tuning Open Source LLMs

This document provides a comprehensive guide on running and fine-tuning open-source large language models (LLMs), covering hardware selection, model selection, quantization, serving inference, and fine-tuning processes. It emphasizes the importance of choosing the right GPUs, understanding model capabilities, and optimizing performance through techniques like quantization and caching. The guide aims to assist users in effectively managing their LLM inference needs while ensuring cost-effectiveness and customization.

Uploaded by

Prabhash Mishra
Copyright
© © All Rights Reserved
We take content rights seriously. If you suspect this is your content, claim it here.
Available Formats
Download as PDF, TXT or read online on Scribd
0% found this document useful (0 votes)
62 views16 pages

Running and Fine-Tuning Open Source LLMs

This document provides a comprehensive guide on running and fine-tuning open-source large language models (LLMs), covering hardware selection, model selection, quantization, serving inference, and fine-tuning processes. It emphasizes the importance of choosing the right GPUs, understanding model capabilities, and optimizing performance through techniques like quantization and caching. The guide aims to assist users in effectively managing their LLM inference needs while ensuring cost-effectiveness and customization.

Uploaded by

Prabhash Mishra
Copyright
© © All Rights Reserved
We take content rights seriously. If you suspect this is your content, claim it here.
Available Formats
Download as PDF, TXT or read online on Scribd
You are on page 1/ 16

🚋

Comprehensive Overview of
Running and Fine-tuning Open
Source LLMs
1. Introduction
2. Why Run Your Own LLM Inference?
3. 🔧 Hardware Selection
3.1 🚀 GPUs: The Workhorses of LLM Inference
3.2 🧠 Understanding the LLM Inference Workload
3.3 ⚡ Why GPUs Excel
3.4 🎯 Choosing the Right GPU
3.5 🔥 Recommended NVIDIA GPUs
3.6 🏁 Alternatives to NVIDIA
3.7 The Importance of Quantization
3.8 ☁️ Modal: Simplifying GPU Access
4. 🤖 Model Selection
4.1 🌍 Navigating the LLM Landscape
4.2 📌 Essential Considerations
4.3 🏆 Leading Contenders
4.4 💡 Ones to Watch
4.5 🧪 The Importance of Evaluation
4.6 📌 Beyond Raw Performance
4.7 Starting Point

Comprehensive Overview of Running and Fine-tuning Open Source LLMs 1


5. ⚡ Quantization: Shrinking LLMs for Efficiency
5.1❓ Why Quantize?
5.2 🔧 Quantization Techniques
5.3 🎯 Quantization Levels
5.4 ✅ Choosing the Right Quantization
5.5 📊 Evaluating Quantized Models
5.6 🛠️ Tools and Resources
5.7 ⚠️ Key Considerations
6. 🚀 Serving Inference: Optimizing for Speed and Efficiency
6.1 ⚡ The Need for Optimization
6.2 🔑 Key Optimizations
6.3 🛠️ Inference Frameworks
6.4 📊 Performance Debugging and Profiling
6.5 📡 Monitoring Key Metrics
6.6 ☁️ Modal for Simplified Deployment
7. 🚀 Fine-Tuning: Customizing LLMs for Your Needs
7.1 🧐 When to Fine-Tune
7.2 ⚠️ Challenges of Fine-Tuning
7.3 🛠 Tools and Techniques
7.4 🔄 Fine-Tuning Workflow
7.5 💡 Key Considerations
8. 🔍 Observability and Continuous Improvement: The LLM Feedback Loop
8.1 📊 The Importance of Observability
8.2 🔄 Building a Continuous Improvement Loop
8.3 🛠 Specialized Tooling
8.4 📈 Evaluation Strategies
8.5 ⚠️ Key Considerations
9. 🎯 Conclusion
10. References

1. Introduction
Running and fine-tuning open-source LLMs have become essential practices in
the field of natural language processing (NLP). This guide provides a detailed
overview of the processes involved, the tools and frameworks used, and best
practices for optimizing performance.

2. Why Run Your Own LLM Inference?


1. Cost Savings: Running your own LLM inference can be more cost-effective
than using proprietary models, especially if you have idle GPUs or can distill

Comprehensive Overview of Running and Fine-tuning Open Source LLMs 2


a smaller model from a proprietary one.

2. Security and Data Governance: Managing your own inference allows for
better control over data privacy and security.

3. Customization: Running your own models enables you to customize them


for specific tasks or domains, which can improve performance and
relevance.

4. Hackability and Integration: Open-source models are easier to hack on


and integrate with other systems, providing more flexibility.

5. Access to Reasoning Chains and Logprobs: Running your own models


gives you access to reasoning chains and log probabilities, which can be
useful for debugging and improving model performance.

3. 🔧 Hardware Selection
3.1 🚀 GPUs: The Workhorses of LLM Inference
Currently, NVIDIA GPUs reign supreme for running LLM inference due to their
superior performance in handling the demanding mathematical computations
and high memory bandwidth requirements. Let’s delve into the technical details
of why this is the case.

3.2 🧠 Understanding the LLM Inference Workload


LLM inference involves feeding input data (e.g., a prompt) through the model to
generate a response. This process requires:

Moving massive amounts of data: The model’s weights (millions or billions


of floating-point numbers) need to be loaded into memory and continuously
transferred to the processing units.

Performing billions of calculations: Each input token triggers a cascade of


mathematical operations across the model’s layers.

3.3 ⚡ Why GPUs Excel


GPUs are specifically designed for such workloads. Unlike CPUs, which
prioritize complex control flow and handling multiple tasks concurrently, GPUs
are optimized for raw computational throughput. They possess:

Massive Parallelism: Thousands of smaller cores work in parallel,


crunching through the matrix multiplications and other mathematical

Comprehensive Overview of Running and Fine-tuning Open Source LLMs 3


operations that dominate LLM inference.

High Memory Bandwidth: Specialized memory architectures enable rapid


data transfer between memory and processing units, minimizing
bottlenecks.

Optimized Kernels: Highly tuned software routines for core operations like
matrix multiplication ensure maximum efficiency on the GPU hardware.

3.4 🎯 Choosing the Right GPU


While the latest and greatest GPUs might seem tempting, the sweet spot for
LLM inference lies with NVIDIA GPUs from one or two generations back. This is
because:

Maturity and Stability: More mature GPUs have well-optimized software


stacks and are less prone to issues.

Cost-Effectiveness: Newer GPUs command a premium price, while slightly


older models offer excellent performance at a lower cost.

VRAM Capacity: The primary constraint for LLM inference is often the
amount of video RAM (VRAM) available to hold the model’s weights and
intermediate activations. Older generation GPUs often have ample VRAM
for most models.

3.5 🔥 Recommended NVIDIA GPUs


🚀 Hopper (H100): While technically a training GPU, the H100’s exceptional
memory bandwidth and compute capabilities make it a strong contender for
inference, especially for larger models.

⚡ Lovelace (L40S): Specifically designed for inference, the L40S balances


performance and efficiency.

🔩 Ampere (A10): A reliable workhorse with wide availability and good


performance for a variety of models.

3.6 🏁 Alternatives to NVIDIA


🟥 AMD and Intel GPUs: While improving, they still lag behind NVIDIA in
performance and software maturity.

☁️ Google TPUs: Powerful but limited to Google Cloud and less versatile
than GPUs.

Comprehensive Overview of Running and Fine-tuning Open Source LLMs 4


🧪 Other Accelerators (Groq, Cerebras): Too cutting-edge and expensive
for most use cases.

3.7 The Importance of Quantization


Quantization techniques, which reduce the precision of numerical
representations (e.g., from 32-bit to 16-bit or even lower), can significantly
improve inference performance by:

Reducing VRAM usage: Smaller numerical representations require less


memory.

Increasing memory bandwidth: More data can be transferred in the same


amount of time.

Enabling faster computations: Some GPUs have specialized hardware for


lower-precision arithmetic.

3.8 ☁️ Modal: Simplifying GPU Access


If managing your own GPU infrastructure seems daunting, consider platforms
like Modal, which abstract away the complexities of provisioning and scaling
GPU resources. Modal allows you to focus on your LLM application while they
handle the underlying infrastructure.

In summary, careful consideration of your model’s size, performance


requirements, and budget will guide you towards the optimal GPU selection for
your LLM inference needs. Remember that VRAM capacity, compute capability,
and memory bandwidth are key factors to consider. While NVIDIA currently
dominates the landscape, stay informed about advancements in the rapidly
evolving field of AI accelerators.

4. 🤖 Model Selection
4.1 🌍 Navigating the LLM Landscape
Choosing the right model is a critical step in your LLM journey. The open-
source LLM ecosystem is rapidly expanding, offering a diverse array of models
with different strengths, weaknesses, and licensing terms.

4.2 📌 Essential Considerations


Before diving into specific models, it’s crucial to:

Comprehensive Overview of Running and Fine-tuning Open Source LLMs 5


1. Define Your Task: What specific problem are you trying to solve? Different
models excel at different tasks, such as text generation, code generation,
translation, question answering, or reasoning.

2. Establish Evaluation Metrics: How will you measure the model’s


performance? Having clear evaluation metrics allows you to compare
different models objectively and make informed decisions.

4.3 🏆 Leading Contenders


🦙 Meta’s LLaMA Series: These models are well-regarded for their
performance and have garnered significant community support. This
translates to a thriving ecosystem of tools and resources:

⚡ Quantization: Neural Magic (Marlin, Machete, Sparse LLaMA) offers


optimized, quantized versions for efficient inference.

Fine-tuning: NousResearch (Hermes) provides fine-tuned variants for


specific tasks and improved behavior.

Merging: Arcee AI (Supernova) enables merging multiple LLaMA models to


create even more powerful ones.

🚀 DeepSeek Series: This rising star from China offers competitive


performance and a more permissive MIT license, making it attractive for
commercial applications. While the tooling ecosystem is still developing, it’s
rapidly growing.

4.4 💡 Ones to Watch


Microsoft Phi: Small but mighty, these models are designed for efficiency.

Allen Institute’s Olmo: Known for strong performance on various


benchmarks.

Mistral: A relatively new entrant showing promising results.

Qwen: Another strong contender from China with a focus on multilingual


capabilities.

Snowflake Arctic: Designed for integration with Snowflake’s data cloud


platform.

Databricks DBRX: Optimized for large-scale data processing and


knowledge retrieval.

Comprehensive Overview of Running and Fine-tuning Open Source LLMs 6


4.5 🧪 The Importance of Evaluation
Don’t get caught up in hype or raw benchmarks. The best model for your needs
is the one that performs best on your specific task and dataset. Always
evaluate multiple models and compare their performance using your own
evaluation metrics.

4.6 📌 Beyond Raw Performance


Consider factors beyond raw performance:

📜 Licensing: Ensure the model’s license aligns with your intended use
case.

🌐 Community: A strong community ensures ongoing support,


development, and a vibrant ecosystem of tools.

📖 Documentation: Clear and comprehensive documentation makes it


easier to understand and use the model effectively.

4.7 Starting Point


If you’re unsure where to begin, Meta’s LLaMA series is a solid starting point
due to its maturity, performance, and extensive community support. However,
always explore other options and evaluate them based on your specific
requirements.
In conclusion, by carefully considering your task, evaluation metrics, and the
factors mentioned above, you can navigate this landscape and choose the best
model for your LLM inference needs.

5. ⚡ Quantization: Shrinking LLMs for Efficiency


Quantization is a crucial technique for optimizing LLM inference performance. It
involves reducing the numerical precision of a model’s weights and/or
activations, leading to significant efficiency gains without substantial loss of
accuracy.

5.1 ❓ Why Quantize?


LLMs, especially large ones, have massive memory footprints. Their billions of
parameters (weights) consume significant storage and memory bandwidth.
Quantization addresses this by:

Comprehensive Overview of Running and Fine-tuning Open Source LLMs 7


Reducing VRAM usage: Smaller numerical representations require less
memory, enabling you to run larger models or multiple models on the same
hardware.

Improving memory bandwidth: More data can be transferred between


memory and processing units in the same amount of time, alleviating
bottlenecks.

Enabling faster computations: Some GPUs have specialized hardware for


lower-precision arithmetic, leading to faster computations.

5.2 🔧 Quantization Techniques


Weight Quantization: This involves reducing the precision of the model’s
weights. A common approach is to convert 32-bit floating-point numbers
(FP32) to 16-bit (FP16 or BF16). This halves the memory requirements with
minimal impact on accuracy.

Activation Quantization: This involves reducing the precision of the


intermediate activations within the model during inference. This can further
improve performance, but it requires more recent GPUs with support for
lower-precision arithmetic and optimized kernels.

5.3 🎯 Quantization Levels


FP16/BF16: A safe and widely supported option, often used for weight
quantization.

INT8: Offers a good balance between performance and accuracy.

INT4/INT3: More aggressive quantization with potential for greater


efficiency but requires careful evaluation of the trade-off with accuracy.

Binary/Ternary: Extreme quantization where weights are represented using


only one or two bits. This can lead to significant memory savings but may
require specialized hardware or software support.

5.4 ✅ Choosing the Right Quantization


The optimal quantization strategy depends on various factors:

Model Architecture: Some models are more amenable to quantization than


others.

Comprehensive Overview of Running and Fine-tuning Open Source LLMs 8


Task Complexity: More complex tasks might require higher precision to
maintain accuracy.

Hardware Support: Recent GPUs offer better support for lower-precision


computations.

Performance Goals: Balance the desired performance gains with


acceptable accuracy trade-offs.

5.5 📊 Evaluating Quantized Models


Always evaluate the impact of quantization on your model’s performance using
your own evaluation metrics and datasets. Don’t rely solely on benchmarks, as
they might not reflect your specific use case.

5.6 🛠️ Tools and Resources


Neural Magic: Offers optimized, quantized versions of popular LLMs.

vLLM: Provides support for running quantized models efficiently.

5.7 ⚠️ Key Considerations


Accuracy: Quantization can introduce some loss of accuracy. Carefully
evaluate the trade-off between performance and accuracy.

Hardware: Recent GPUs are better equipped to handle lower-precision


computations.

Software: Ensure your inference framework and tools support the desired
quantization level.

In conclusion, quantization is a powerful technique for optimizing LLM


inference performance. By carefully choosing the appropriate quantization
strategy and evaluating its impact, you can achieve significant efficiency gains
without compromising accuracy.

6. 🚀Serving Inference: Optimizing for Speed and


Efficiency
Serving LLM inference efficiently is crucial for delivering a smooth and
responsive user experience, especially as demand scales. Optimizing this

Comprehensive Overview of Running and Fine-tuning Open Source LLMs 9


process involves careful consideration of various factors, from hardware
utilization to software frameworks and algorithmic techniques.

6.1 ⚡ The Need for Optimization


LLM inference can be computationally expensive, requiring significant
processing power and memory bandwidth. Efficient inference aims to:

Reduce Latency: Minimize the time it takes to generate a response to a


user’s request.

Increase Throughput: Maximize the number of requests that can be


processed concurrently.

Lower Costs: Optimize resource utilization to reduce the cost of running


inference.

6.2 🔑 Key Optimizations


KV Caching: LLMs maintain a “key-value” cache of past activations to
efficiently process long sequences. Optimizing this cache can significantly
reduce redundant computations and improve performance.

Continuous Batching: Batching multiple inference requests together allows


the GPU to process them more efficiently. Continuous batching dynamically
groups requests as they arrive, minimizing latency while maximizing
throughput.

Speculative Decoding: This technique involves generating multiple


possible next tokens in parallel and then selecting the most likely one. This
can improve throughput by reducing the time spent waiting for the model to
generate each token sequentially.

Kernel Optimization: Fine-tuning low-level GPU kernels for specific


operations can lead to significant performance improvements.

6.3 🛠️ Inference Frameworks


Specialized inference frameworks provide pre-built optimizations and tools to
simplify the deployment and management of LLM inference:

vLLM: A high-performance inference engine developed by UC Berkeley. It


offers excellent performance, ease of use, and features like:

Paged KV Caching: Efficiently handles long sequences.

Comprehensive Overview of Running and Fine-tuning Open Source LLMs 10


OpenAI-Compatible API: Simplifies integration with existing
applications.

PyTorch Integration: Leverages the PyTorch ecosystem and tools.

NVIDIA TensorRT: NVIDIA’s inference optimization platform. It includes:

• ⚡ TensorRT-LLM: A plugin specifically for optimizing LLM inference.


• 📡 Triton Inference Server: A platform for deploying and managing
inference models.

📌 Other Frameworks: Explore other options like lmdeploy, mlc-llm, and


sglang, each with its own strengths and focus.

6.4 📊 Performance Debugging and Profiling


Identifying and resolving performance bottlenecks is crucial for optimizing
inference. Utilize profiling tools to gain insights into your inference pipeline:

PyTorch Tracer/Profiler: Provides detailed information about the execution


of PyTorch models.

NVIDIA NSight: Offers in-depth profiling and analysis of GPU performance.

6.5 📡 Monitoring Key Metrics


Track these metrics to assess and improve inference performance:

🎛️ GPU Utilization: Ensure the GPU is being effectively utilized.


⚡ Power Consumption: Monitor power usage to identify potential
inefficiencies.

🌡️ Temperature: High temperatures can indicate performance issues or


potential hardware problems.

⏳ Latency: Measure the time it takes to process inference requests.


📊 Throughput: Track the number of requests processed per unit of time.
6.6 ☁️ Modal for Simplified Deployment
Platforms like Modal simplify the deployment and scaling of LLM inference by
abstracting away infrastructure management. They offer serverless GPUs, pre-
built containers, and tools for monitoring and optimizing performance.

Conclusion

Comprehensive Overview of Running and Fine-tuning Open Source LLMs 11


Efficient LLM inference involves a combination of optimized algorithms,
specialized frameworks, and careful performance tuning. By leveraging these
techniques and tools, you can deliver a responsive and cost-effective LLM
experience to your users.

7. 🚀 Fine-Tuning: Customizing LLMs for Your Needs


Fine-tuning allows you to adapt a pre-trained LLM to better suit your specific
requirements. This involves further training the model on a new dataset,
refining its parameters to improve performance on a particular task or domain.

7.1 🧐 When to Fine-Tune


Knowledge Transfer: Distill knowledge from a larger, proprietary model
(like GPT-4) into a smaller, open-source model, making it more cost-
effective to run.

Style Control: Train the model to consistently generate text in a specific


style (e.g., formal, informal, creative) or tone.

Task Specialization: Improve performance on a specific task, such as


code generation, translation, or question answering, by fine-tuning on a
relevant dataset.

7.2 ⚠️ Challenges of Fine-Tuning


Fine-tuning LLMs is a complex undertaking with several challenges:

Resource Intensive: Fine-tuning requires significant computational


resources, especially for larger models. You’ll need powerful GPUs and
ample memory to handle the training process.

Data Requirements: High-quality data is crucial for effective fine-tuning.


You’ll need a substantial dataset that is relevant to your target task or
domain.

Hyperparameter Tuning: Finding the optimal hyperparameters (e.g.,


learning rate, batch size) can be challenging and require experimentation.

Evaluation: Rigorous evaluation is essential to ensure that fine-tuning


improves the model’s performance on your target task.

7.3 🛠 Tools and Techniques


Comprehensive Overview of Running and Fine-tuning Open Source LLMs 12
Parameter-Efficient Fine-Tuning: Techniques like LoRA (Low-Rank
Adaptation) enable fine-tuning with reduced memory requirements by only
updating a small subset of the model’s parameters.

Experiment Tracking: Tools like Weights & Biases, MLFlow, and Neptune
help you track experiments, log metrics, and visualize results, making it
easier to manage the fine-tuning process.

Jupyter Notebooks: Notebooks provide an interactive environment for


experimentation and development, allowing you to quickly iterate and try
out different ideas.

Internal Libraries: Organize reusable code into internal libraries to


streamline your workflow and maintain consistency across experiments.

7.4 🔄 Fine-Tuning Workflow


1. Prepare Data: Gather and clean a dataset relevant to your target task.

2. Choose a Base Model: Select a pre-trained model suitable for your task.

3. Set Up Infrastructure: Ensure you have sufficient GPU resources and


install the necessary software and tools.

4. Fine-Tune the Model: Train the model on your new dataset, adjusting
hyperparameters as needed.

5. Evaluate Performance: Assess the model’s performance on your target


task using appropriate metrics.

6. Iterate and Refine: Repeat the process, refining the dataset,


hyperparameters, and fine-tuning techniques to further improve
performance.

7.5 💡 Key Considerations


Cost: Fine-tuning can be expensive. Consider the cost of GPUs, storage,
and engineering time.

Time: Fine-tuning can take a significant amount of time, especially for


larger models and datasets.

Expertise: Fine-tuning requires expertise in machine learning and deep


learning.

Comprehensive Overview of Running and Fine-tuning Open Source LLMs 13


🎯 Conclusion
Fine-tuning is a powerful technique for customizing LLMs to better address
specific needs. While it presents challenges, careful planning, the right tools,
and a systematic approach can lead to significant improvements in model
performance.

8. 🔍
Observability and Continuous Improvement:
The LLM Feedback Loop
Observability and continuous improvement are essential aspects of running
LLMs in production. They involve collecting data, monitoring performance, and
using feedback to refine your models and applications.

8.1 📊 The Importance of Observability


LLMs can exhibit unexpected behaviors and biases, making it crucial to monitor
their performance in real-world scenarios. Observability allows you to:

Detect and diagnose issues: Identify problems like inaccurate outputs,


biased responses, or performance degradation.

Understand user behavior: Gain insights into how users interact with your
LLM application and what types of prompts they use.

Gather training data: Collect valuable data for fine-tuning and improving
your models.

8.2 🔄 Building a Continuous Improvement Loop


The goal is to create a virtuous cycle where user interactions and feedback
continuously improve your LLM application. This involves:

1. Capturing User Data: Log user prompts, model responses, and any
relevant metadata (e.g., timestamps, user demographics).

2. Annotating Data: Add labels or annotations to the data to indicate the


quality of the model’s responses (e.g., correct, incorrect, biased).

3. Collecting into Evals: Aggregate the annotated data into evaluation


datasets to assess model performance and identify areas for improvement.

4. Refining the Model: Use the evaluation data to fine-tune your model,
update its knowledge base, or adjust its parameters.

Comprehensive Overview of Running and Fine-tuning Open Source LLMs 14


8.3 🛠 Specialized Tooling
Offline Evals (e.g., W&B Weave): Tools like Weave enable offline evaluation
by collecting data, running analysis, and visualizing results. This is useful
for in-depth analysis and experimentation.

Online Evals (e.g., LangSmith): LangSmith and similar tools provide online
evaluation capabilities, allowing you to monitor model performance in real-
time and quickly identify issues.

Build Your Own: For more customized solutions, consider building your
own observability pipeline using tools like OpenTelemetry and ClickHouse.

8.4 📈 Evaluation Strategies


A/B Testing: Compare different versions of your model or prompts to see
which performs better.

Human Evaluation: Involve human annotators to assess the quality and


relevance of model responses.

Metrics: Track metrics like accuracy, F1-score, BLEU score, or perplexity to


measure model performance.

8.5 ⚠️ Key Considerations


Data Privacy: Ensure you handle user data responsibly and comply with
relevant privacy regulations.

Bias Detection: Implement mechanisms to detect and mitigate biases in


your models and datasets.

Explainability: Strive to understand and explain the reasoning behind your


model’s outputs.

🎯 Conclusion
Observability and continuous improvement are crucial for building and
maintaining high-quality LLM applications. By establishing a feedback loop and
leveraging specialized tooling, you can ensure your LLMs are performing
optimally and meeting your users’ needs.

9. 🎯 Conclusion
Running and fine-tuning open-source LLMs require a deep understanding of
the underlying hardware, software frameworks, and optimization techniques.

Comprehensive Overview of Running and Fine-tuning Open Source LLMs 15


By following best practices and leveraging the right tools, you can achieve
cost-effective, secure, and high-performance LLM inference tailored to your
specific needs.

10. References
1. Fine-Tuning Open-Source Language Models: A Step-by-Step Guide
2. SuperAnnotate’s LLM Tool for Fine-Tuning Language Models
3. Fine-Tuning LLMs: Overview, Methods & Best Practices

4. A Comprehensive Guide to Fine-Tune Open-Source LLMs Using Lamini


5. The Ultimate Guide to Fine-Tuning LLMs from Basics to Breakthroughs
6. Fine Tuning LLM for Enterprise: Practical Guidelines and
Recommendations
7. LlamaFactory: Unified Efficient Fine-Tuning of 100+ Language Models

8. Fine-Tuning LLMs: A Guide With Examples


9. https://github.com/Curated-Awesome-Lists/awesome-llms-fine-tuning

Comprehensive Overview of Running and Fine-tuning Open Source LLMs 16

You might also like