Developing an LLM: Building, Training, Finetuning

แชร์
ฝัง
  • เผยแพร่เมื่อ 2 ม.ค. 2025

ความคิดเห็น •

  • @nintishia
    @nintishia หลายเดือนก่อน +3

    The hallmark of a great teacher is to teach the essentials with depth. Sebastian succeeds fabulously. Thanks for the video.

    • @SebastianRaschka
      @SebastianRaschka  14 วันที่ผ่านมา

      Thanks for the kind compliment, I am glad to hear that you found these videos helpful!

  • @tusharganguli
    @tusharganguli 6 หลายเดือนก่อน +18

    Your articles and videos have been extremely helpful in understanding how LLMs are built. Building LLM from Scratch and Q and AI are resources that I am presently reading and they provide a hands-on discourse on the conceptual understanding of LLMs. You, Andrej Karpathy and Jay Alammar are shining examples of how learning should be enabled. Thank you!

    • @SebastianRaschka
      @SebastianRaschka  6 หลายเดือนก่อน +1

      Thanks for the kind comment!

  • @box-mt3xv
    @box-mt3xv 7 หลายเดือนก่อน +30

    The hero of open source

    • @SebastianRaschka
      @SebastianRaschka  6 หลายเดือนก่อน +2

      Haha, thanks! I've learned so much thanks to all the amazing people in open source, and I'm very flattered by your comment to potentially be counted as one of them :)

  • @admercs
    @admercs 4 หลายเดือนก่อน +1

    You are a true educator. Honored to be a contributor to one of your libraries.

  • @kyokushinfighter78
    @kyokushinfighter78 4 หลายเดือนก่อน +2

    One of the best 60 minutes of my time. Really thankful for this..

  • @pe6649
    @pe6649 4 หลายเดือนก่อน +1

    Danke!

  • @nithinma8697
    @nithinma8697 4 หลายเดือนก่อน +4

    00:02 Three common ways of using large language models
    02:39 Developing LLM involves building, pre-training, and fine-tuning.
    07:11 LLM predicts the next token in the text
    09:30 Training LLM involves sliding fixed size inputs over text data to create batches.
    14:22 Byte pair encoding and sentence piece variations allow LLMs to handle unknown words
    16:42 Training sets are increasing in size
    21:09 Developing an LM involves architecture, pre-training, model evaluation, and fine-tuning.
    23:14 The Transformer block is repeated multiple times in the architecture.
    27:22 Pre-training creates the Foundation model for fine-tuning
    29:28 Training LLMs typically done for one to two epochs
    33:44 Pre-training is not usually necessary for adapting LLM for a certain task
    35:51 Replace the output layer for efficient classification.
    39:54 Classification fine-tuning is key for practical business tasks.
    42:01 LLM instruction data set and preference tuning
    45:58 Evaluating LLMs is crucial, with MML being a popular metric.
    48:07 Multiple choice questions are not sufficient to measure an LM's performance
    52:34 Comparing LLM models for performance evaluation
    54:32 Continued pre-training is effective for instilling new knowledge in LLMs
    58:28 Access slides on the website for more details

  • @adityasamalla3251
    @adityasamalla3251 4 หลายเดือนก่อน +5

    You are the best! Thanks a lot for sharing your knowledge to the world.

  • @chineduezeofor2481
    @chineduezeofor2481 6 หลายเดือนก่อน +3

    Thank you Sebastian for your awesome contributions. You're a big inspiration.

  • @guis487
    @guis487 5 หลายเดือนก่อน +1

    I am your fan, I have most of your books, thanks for this excellent video ! Another evaluation metric that I found interesting in another channel was to make the LLMs to play chess against each other 10 times.

    • @SebastianRaschka
      @SebastianRaschka  5 หลายเดือนก่อน

      Hah nice, that's a fun one. How do you evaluate who's the winner, do you use a third LLM for that?

  • @haribhauhud8881
    @haribhauhud8881 4 หลายเดือนก่อน +1

    Thank you, Sir. Your lessons are beneficial for the community. Appreciate your hard work..!! 😊

  • @tomhense6866
    @tomhense6866 6 หลายเดือนก่อน +1

    Very nice video, I liked it so much that I preordered your new book directly after watching it (to be fair I have read your blog for some time now).

    • @SebastianRaschka
      @SebastianRaschka  6 หลายเดือนก่อน

      Thanks! I hope you are going to like the book, too!

  • @ZavierBanerjea
    @ZavierBanerjea 5 หลายเดือนก่อน +1

    What wonderful Tech Minds : { Sebastian Raschka, Yann LeCun, Andrej Karpathy, ...} who share their works and beautiful ideations for Mere mortal like me... Sebastian's teachings are so, so fundamental that takes fear off my clogged mind... 🙏
    Although I am struggling to build LLMs for specific & niche areas, I am confidant of cracking them with great resources like : Build a Large Language Model (From Scratch)!!!

  • @DataChiller
    @DataChiller 6 หลายเดือนก่อน +6

    the greatest Liverpool fan ever! ⚽

    • @SebastianRaschka
      @SebastianRaschka  6 หลายเดือนก่อน +5

      Haha nice, at least one person watched it until that part :D

  • @Xnaarkhoo
    @Xnaarkhoo 4 หลายเดือนก่อน +1

    @16:37 when you say Llama was trained on 1T token, do you still mean there was 32K unique token ? because on your blog post you have "They also have a surprisingly large 151,642 token vocabulary (for reference, Llama 2 uses a 32k vocabulary, and Llama 3.1 uses a 128k token vocabulary); as a rule of thumb, increasing the vocab size by 2x reduces the number of input tokens by 2x so the LLM can fit more tokens into the same input. Also it especially helps with multilingual data and coding to cover words outside the standard English vocabulary."

    • @SebastianRaschka
      @SebastianRaschka  4 หลายเดือนก่อน

      Thanks for the comment! So in the talk these are the dataset sizes using the respective tokenizer that was used during model training. The vocabulary sizes that the models used are 32k for Llama 2 and 128k for Llama 3.1. So, regarding "do you still mean there was 32K unique token", the vocabulary was 32k unique tokens (but there could be more unique tokens in the dataset). I hope this helps. Otherwise, please let me know, happy to explain more!

  • @bjugdbjk
    @bjugdbjk 3 หลายเดือนก่อน

    u r a LEGEND,luv ur work,thnx a ton for sharing!

  • @katelee872
    @katelee872 หลายเดือนก่อน

    super, thanks so much, you are hero of us.

  • @haqiufreedeal
    @haqiufreedeal 6 หลายเดือนก่อน +3

    Oh, my lord, my favourite machine learning author is a Liverpool fan.😎

    • @SebastianRaschka
      @SebastianRaschka  6 หลายเดือนก่อน +1

      Haha, nice that people make it that far into the video 😊

    • @ananthvankipuram4012
      @ananthvankipuram4012 6 หลายเดือนก่อน

      @@SebastianRaschka You'll never walk alone 🙂

  • @rachadlakis1
    @rachadlakis1 7 หลายเดือนก่อน +3

    Thanks for the great knowledge You are sharing

  • @sahilsharma3267
    @sahilsharma3267 7 หลายเดือนก่อน +4

    When is your whole book coming out ? Eagerly waiting 😅

    • @SebastianRaschka
      @SebastianRaschka  7 หลายเดือนก่อน +2

      Thanks for your interest in this! It's already available for preorder (both on the publisher's website and Amazon) and if the production stage goes smoothly, it should be out by the end of of August

  • @moshoodolawale3591
    @moshoodolawale3591 4 หลายเดือนก่อน +1

    Thanks for the detailed videos and articles. I want to ask if it's possible to create a customized tokenizer as an extension to existing ones for a custom dataset? Also, how do decoder-only models handle other tasks like summarization, and classification after fine-tuning without forgetting their causal pre-trained causal next token task?

    • @SebastianRaschka
      @SebastianRaschka  4 หลายเดือนก่อน

      Good question. Yes you, can do that, tiktoken for example allows you to extend the vocabulary with additional tokens. However, you have to keep in mind that you'll always have to update the embedding layer and output layer with these tokens in case you want to use the updated tokenizer with an existing LLM. Regarding your second question, you could do that but that would not be ideal because only the last tokens contains information about all other tokens. If you use other tokens, you'll have more information loss.

  • @RobinSunCruiser
    @RobinSunCruiser 6 หลายเดือนก่อน +1

    Hi, nice videos! One question for my understanding. When talking about embedding dimensions such as 1280 in "gpt2-large" do you mean the size of the number vector encoding the context of a single token or the number of input tokens? When comparing gpt2-large and Lama2 the number is the same for the ".. embeddings with 1280 tokens".

    • @SebastianRaschka
      @SebastianRaschka  6 หลายเดือนก่อน

      Good question, the term is often used very broadly and may refer to the input embeddings or the hidden layer sizes in the MLP layer. Here, I meant the size of the tokens that are embedded.

  • @alokranjansrivastava623
    @alokranjansrivastava623 4 หลายเดือนก่อน +1

    Nice Video.
    Does LLM mean only auto-regressive models (Not Bert)?

    • @SebastianRaschka
      @SebastianRaschka  4 หลายเดือนก่อน

      Yes, here LLM is basically synonymous with decoder-style autoregressive model like Llama, GPT, Gemma, etc.

    • @alokranjansrivastava623
      @alokranjansrivastava623 4 หลายเดือนก่อน

      @@SebastianRaschka Bert has stack of encoder transformers, but it is not LLM. Am I correct here?

    • @SebastianRaschka
      @SebastianRaschka  4 หลายเดือนก่อน

      @@alokranjansrivastava623 Architecture-wise, it's kind of the same thing though, except it doesn't have the causal mask, and the pretraining task is not next-token prediction but predicting masked tokens (plus sentence order prediction).

    • @alokranjansrivastava623
      @alokranjansrivastava623 4 หลายเดือนก่อน

      ​@@SebastianRaschkaJust One question. How to define LLM? When we can say that this particular Language model is of LLM category.

  • @muthukamalan.m6316
    @muthukamalan.m6316 7 หลายเดือนก่อน +1

    great content! love it ❤

  • @andreyc.3600
    @andreyc.3600 4 หลายเดือนก่อน +1

    Ich nehme stark an, dass Du Deutsch sprichst :). Wo kann man Dein Buch im Kindle (mobi oder f2b) Format finden? Danke & LG.

    • @SebastianRaschka
      @SebastianRaschka  4 หลายเดือนก่อน

      Vielen Dank fuer das Interesse an meinem Buch. So weit ich es vom Verlag mitbekommen habe wird diese Woche zum Drucker geschickt und dann sollte es hoffentlich in ein paar Wochen auch bein Amazon.com/.de als Kindle Version erhaeltlich werden.

    • @andreyc.3600
      @andreyc.3600 4 หลายเดือนก่อน

      @@SebastianRaschka super, vielen Dank.

  • @KumR
    @KumR 6 หลายเดือนก่อน +1

    Great Video. Now that LLM is so powerful , will regular machine learning & deep learning slowly vanish?

    • @SebastianRaschka
      @SebastianRaschka  6 หลายเดือนก่อน +1

      Great question. I do think that special purpose ML solutions still have and will continue to have their place. The same way ML didn't make certain more traditional statistics based models obsolete. Regarding deep learning ... I'd say LLM is a deep learning model itself. But yeah, almost everything in deep learning is nowadays either a diffusion model, transformer-based model (vision transformer and most LLMs), or state space model

  • @superfreiheit1
    @superfreiheit1 9 วันที่ผ่านมา

    I would like to create a chatbot for arxiv publications. I do not understand how to create the instuction or qa-Dataset for it. Can you make a tutorial?

  • @bashamsk1288
    @bashamsk1288 7 หลายเดือนก่อน +1

    in the instruction fine tuning we propagate loss only on output text tokens? or for all tokens from start to EOS?

    • @SebastianRaschka
      @SebastianRaschka  7 หลายเดือนก่อน +1

      That's a good question. You can do both. By default all tokens, but more commonly you'd mask the tokens. In my book, I include the token masking as a reader exercise (it's super easy to do). There was also a new research paper a few weeks ago that I discussed in my monthly research write-ups here: magazine.sebastianraschka.com/p/llm-research-insights-instruction

    • @bashamsk1288
      @bashamsk1288 7 หลายเดือนก่อน

      @@SebastianRaschka
      Thanks for the reply
      I just have a general question: do we use masking? For example, was masking used during the instruction fine-tuning of LLaMA 3 or mistral any Open source LLMs? Also, does your book include any chapters on the parallelization of training large language models?

    • @SebastianRaschka
      @SebastianRaschka  7 หลายเดือนก่อน

      @@bashamsk1288 Masking is commonly used, yes. We implement it as the default strategy in LitGPT. In my book we do both. I can't speak about Llama 3 and Mistral regarding masking, because while these are open-weight models they are not open source. So there's no training code we can look at. My book explains DDP training in the PyTorch appendix, but it's not used in the main chapters because as a requirement all chapters should also work on a laptop to make them accessible to most readers.

  • @tashfeenahmed3526
    @tashfeenahmed3526 6 หลายเดือนก่อน

    That's great Dr. Hope you will be doing good.
    I wish if i could download your deep learning book which is published recently. If there is any open source link to download it please mention in comments.
    Thanks and regards,
    Researcher at Texas

  • @timothywcrane
    @timothywcrane 6 หลายเดือนก่อน +1

    I'm interested in SLM RAG with Knowledge graph traversal/search for RAG dataset collection and vector-JIT semantic match for hybrid search. Any repos you think I would be interested in?

    • @timothywcrane
      @timothywcrane 6 หลายเดือนก่อน

      bookmarked, clear and concise.

    • @SebastianRaschka
      @SebastianRaschka  6 หลายเดือนก่อน

      Unfortunately I don't have a good recommendation here. I have only implemented standard RAGs without knowledge graph traversal.

  • @alihajikaram8004
    @alihajikaram8004 6 หลายเดือนก่อน

    Would
    you make videos about time series and trannsformer?

  • @ArbaazBeg
    @ArbaazBeg 6 หลายเดือนก่อน

    Should we give prompt to LLM when fine tuning for classification with last layer modification or directly pass the input to the LLM like in deberta?

    • @SebastianRaschka
      @SebastianRaschka  6 หลายเดือนก่อน +1

      Thanks for the comment, could you explain a bit more what you mean by passing the input directly?

    • @ArbaazBeg
      @ArbaazBeg 6 หลายเดือนก่อน +1

      @@SebastianRaschka Hey, sorry for the bad language. I meant should the chat formats like alpaca etc be applied or we give the text as it is to LLM for classification.

    • @SebastianRaschka
      @SebastianRaschka  6 หลายเดือนก่อน +1

      @@ArbaazBeg Oh I see now. And yes, you can. I wanted to create an example and performance comparison for that to the GitHub repo (github.com/rasbt/LLMs-from-scratch) some time. For that I wanted to first instruction-finetune the model on a few more spam classification instructions and examples though.

  • @joisco4394
    @joisco4394 6 หลายเดือนก่อน

    I've heard about instruct learning, and it sounds similar to how you define preference learning. I have also heard about transfer learning. How would you compare/define those?

    • @SebastianRaschka
      @SebastianRaschka  6 หลายเดือนก่อน +1

      Transfer learning is basically involved in everything you do when you start out with a pretrained model. We don't really name or call it out explicitly anymore because it's so common. In instruction finetuning, the loss function is different from preference tuning mainly. Instruction finetuning trains the model to answer queries, and preference finetuning is basically more about the nuance of how these get answered. All preference tuning methods that are used today (DPO, RLHF+PPO, KTO), etc. expect you to have done instruction finetuning on your model before you preference finetune.

    • @joisco4394
      @joisco4394 6 หลายเดือนก่อน +1

      @@SebastianRaschka Thanks for explaining it. I need to do a lot more research :p

    • @SebastianRaschka
      @SebastianRaschka  5 หลายเดือนก่อน +1

      @@joisco4394 Btw I recently coded the alignment (using direct preference optimization) here, which might help clarifying this step: github.com/rasbt/LLMs-from-scratch/blob/main/ch07/04_preference-tuning-with-dpo/dpo-from-scratch.ipynb

    • @joisco4394
      @joisco4394 4 หลายเดือนก่อน

      @@SebastianRaschka Much appreciated

  • @kartiksaini5847
    @kartiksaini5847 7 หลายเดือนก่อน +1

    Big fan ❤

  • @zamot155
    @zamot155 22 วันที่ผ่านมา

    32:50 watched this today, 12.12 and that was kind of scary 😅

  • @mushinart
    @mushinart 6 หลายเดือนก่อน +1

    Im sold , im buying your book .. would love to chat with you sometime if possible

    • @SebastianRaschka
      @SebastianRaschka  6 หลายเดือนก่อน +1

      Thanks, hope you are liking it! Are you going to SciPy in July by chance, or maybe Neurips end of the year?

    • @mushinart
      @mushinart 6 หลายเดือนก่อน

      @@SebastianRaschka unfortunately not,but I'd like to have a zoom/google meet chat with you if possible

  • @MadnessAI8X
    @MadnessAI8X 7 หลายเดือนก่อน +1

    What we are seeking not only fuzzing code

  • @ramprasadchauhan7
    @ramprasadchauhan7 6 หลายเดือนก่อน

    Hello sir, please also make with javascript

  • @TheCuriousCurator-Hindi
    @TheCuriousCurator-Hindi 2 หลายเดือนก่อน

    I have been in this field for a while (decade +) but not in touch with LLMs and it is useless for uninformed and even more useless for the informed. I don't know I am in which category but I didn't learn anything. I read about transformers when the paper came then I assumed RLHF is just reinforce algorithm which is probably correct to assume. Anyways highly repellent video.

  • @krum.00
    @krum.00 7 หลายเดือนก่อน +1

    🤌

    • @SebastianRaschka
      @SebastianRaschka  6 หลายเดือนก่อน

      I take that as a compliment!? 😅😊

    • @krum.00
      @krum.00 6 หลายเดือนก่อน +1

      @@SebastianRaschka Yes yes! It was supposed to be a compliment only. You are doing great work with our teaching materials :).

  • @redthunder6183
    @redthunder6183 7 หลายเดือนก่อน

    Easier said than done unless u got a GPU super computer lying around lol

    • @SebastianRaschka
      @SebastianRaschka  6 หลายเดือนก่อน +1

      ha, I should mention that all chapters in my book run on laptops, too. It was a personal goal for me that everything should work even without a GPU. The instruction finetuning takes about ~30 min on a CPU to get reasonable results (granted, the same code takes 1.24 min on an A100)