模型:

TheBloke/wizard-vicuna-13B-SuperHOT-8K-GPTQ

中文

Chat & support: my new Discord server

Want to contribute? TheBloke's Patreon page

June Lee's Wizard Vicuna 13B GPTQ

These files are GPTQ 4bit model files for June Lee's Wizard Vicuna 13B merged with Kaio Ken's SuperHOT 8K .

It is the result of quantising to 4bit using GPTQ-for-LLaMa .

This is an experimental new GPTQ which offers up to 8K context size

The increased context is tested to work with ExLlama , via the latest release of text-generation-webui .

It has also been tested from Python code using AutoGPTQ, and trust_remote_code=True .

Code credits:

  • Original concept and code for increasing context length: kaiokendev
  • Updated Llama modelling code that includes this automatically via trust_remote_code: emozilla .

Please read carefully below to see how to use it.

GGML versions are not yet provided, as there is not yet support for SuperHOT in llama.cpp. This is being investigated and will hopefully come soon.

Repositories available

How to easily download and use this model in text-generation-webui with ExLlama

Please make sure you're using the latest version of text-generation-webui

  • Click the Model tab .
  • Under Download custom model or LoRA , enter TheBloke/wizard-vicuna-13B-SuperHOT-8K-GPTQ .
  • Click Download .
  • The model will start downloading. Once it's finished it will say "Done"
  • Untick Autoload the model
  • In the top left, click the refresh icon next to Model .
  • In the Model dropdown, choose the model you just downloaded: wizard-vicuna-13B-SuperHOT-8K-GPTQ
  • To use the increased context, set the Loader to ExLlama , set max_seq_len to 8192 or 4096, and set compress_pos_emb to 4 for 8192 context, or to 2 for 4096 context.
  • Now click Save Settings followed by Reload
  • The model will automatically load, and is now ready for use!
  • Once you're ready, click the Text Generation tab and enter a prompt to get started!
  • How to use this GPTQ model from Python code with AutoGPTQ

    First make sure you have AutoGPTQ and Einops installed:

    pip3 install einops auto-gptq
    

    Then run the following code. Note that in order to get this to work, config.json has been hardcoded to a sequence length of 8192.

    If you want to try 4096 instead to reduce VRAM usage, please manually edit config.json to set max_position_embeddings to the value you want.

    from transformers import AutoTokenizer, pipeline, logging
    from auto_gptq import AutoGPTQForCausalLM, BaseQuantizeConfig
    import argparse
    
    model_name_or_path = "TheBloke/wizard-vicuna-13B-SuperHOT-8K-GPTQ"
    model_basename = "wizard-vicuna-13b-superhot-8k-GPTQ-4bit-128g.no-act.order"
    
    use_triton = False
    
    tokenizer = AutoTokenizer.from_pretrained(model_name_or_path, use_fast=True)
    
    model = AutoGPTQForCausalLM.from_quantized(model_name_or_path,
            model_basename=model_basename,
            use_safetensors=True,
            trust_remote_code=True,
            device_map='auto',
            use_triton=use_triton,
            quantize_config=None)
    
    model.seqlen = 8192
    
    # Note: check the prompt template is correct for this model.
    prompt = "Tell me about AI"
    prompt_template=f'''USER: {prompt}
    ASSISTANT:'''
    
    print("\n\n*** Generate:")
    
    input_ids = tokenizer(prompt_template, return_tensors='pt').input_ids.cuda()
    output = model.generate(inputs=input_ids, temperature=0.7, max_new_tokens=512)
    print(tokenizer.decode(output[0]))
    
    # Inference can also be done using transformers' pipeline
    
    # Prevent printing spurious transformers error when using pipeline with AutoGPTQ
    logging.set_verbosity(logging.CRITICAL)
    
    print("*** Pipeline:")
    pipe = pipeline(
        "text-generation",
        model=model,
        tokenizer=tokenizer,
        max_new_tokens=512,
        temperature=0.7,
        top_p=0.95,
        repetition_penalty=1.15
    )
    
    print(pipe(prompt_template)[0]['generated_text'])
    

    Using other UIs: monkey patch

    Provided in the repo is llama_rope_scaled_monkey_patch.py , written by @kaiokendev.

    It can be theoretically be added to any Python UI or custom code to enable the same result as trust_remote_code=True . I have not tested this, and it should be superseded by using trust_remote_code=True , but I include it for completeness and for interest.

    Provided files

    wizard-vicuna-13b-superhot-8k-GPTQ-4bit-128g.no-act.order.safetensors

    This will work with AutoGPTQ, ExLlama, and CUDA versions of GPTQ-for-LLaMa. There are reports of issues with Triton mode of recent GPTQ-for-LLaMa. If you have issues, please use AutoGPTQ instead.

    It was created with group_size 128 to increase inference accuracy, but without --act-order (desc_act) to increase compatibility and improve inference speed.

    • wizard-vicuna-13b-superhot-8k-GPTQ-4bit-128g.no-act.order.safetensors
      • Works for use with ExLlama with increased context (4096 or 8192)
      • Works with AutoGPTQ in Python code, including with increased context, if trust_remote_code=True is set.
      • Should work with GPTQ-for-LLaMa in CUDA mode, but unknown if increased context works - TBC. May have issues with GPTQ-for-LLaMa Triton mode.
      • Works with text-generation-webui, including one-click-installers.
      • Parameters: Groupsize = 128. Act Order / desc_act = False.

    Discord

    For further support, and discussions on these models and AI in general, join us at:

    TheBloke AI's Discord server

    Thanks, and how to contribute.

    Thanks to the chirper.ai team!

    I've had a lot of people ask if they can contribute. I enjoy providing models and helping people, and would love to be able to spend even more time doing it, as well as expanding into new projects like fine tuning/training.

    If you're able and willing to contribute it will be most gratefully received and will help me to keep providing more models, and to start work on new AI projects.

    Donaters will get priority support on any and all AI/LLM/model questions and requests, access to a private Discord room, plus other benefits.

    Special thanks to : Luke from CarbonQuill, Aemon Algiz, Dmitriy Samsonov.

    Patreon special mentions : zynix , ya boyyy, Trenton Dambrowitz, Imad Khwaja, Alps Aficionado, chris gileta, John Detwiler, Willem Michiel, RoA, Mano Prime, Rainer Wilmers, Fred von Graf, Matthew Berman, Ghost , Nathan LeClaire, Iucharbius , Ai Maven, Illia Dulskyi, Joseph William Delisle, Space Cruiser, Lone Striker, Karl Bernard, Eugene Pentland, Greatston Gnanesh, Jonathan Leane, Randy H, Pierre Kircher, Willian Hasse, Stephen Murray, Alex , terasurfer , Edmond Seymore, Oscar Rangel, Luke Pendergrass, Asp the Wyvern, Junyu Yang, David Flickinger, Luke, Spiking Neurons AB, subjectnull, Pyrater, Nikolai Manek, senxiiz, Ajan Kanaga, Johann-Peter Hartmann, Artur Olbinski, Kevin Schuppel, Derek Yates, Kalila, K, Talal Aujan, Khalefa Al-Ahmad, Gabriel Puliatti, John Villwock, WelcomeToTheClub, Daniel P. Andersen, Preetika Verma, Deep Realms, Fen Risland, trip7s trip, webtim, Sean Connelly, Michael Levine, Chris McCloskey, biorpg, vamX, Viktor Bowallius, Cory Kujawski.

    Thank you to all my generous patrons and donaters!

    Original model card: Kaio Ken's SuperHOT 8K

    SuperHOT Prototype 2 w/ 8K Context

    This is a second prototype of SuperHOT, this time 30B with 8K context and no RLHF, using the same technique described in the github blog . Tests have shown that the model does indeed leverage the extended context at 8K.

    You will need to use either the monkeypatch or, if you are already using the monkeypatch, change the scaling factor to 0.25 and the maximum sequence length to 8192

    Looking for Merged & Quantized Models? Training Details

    I trained the LoRA with the following configuration:

    • 1200 samples (~400 samples over 2048 sequence length)
    • learning rate of 3e-4
    • 3 epochs
    • The exported modules are:
      • q_proj
      • k_proj
      • v_proj
      • o_proj
      • no bias
    • Rank = 4
    • Alpha = 8
    • no dropout
    • weight decay of 0.1
    • AdamW beta1 of 0.9 and beta2 0.99, epsilon of 1e-5
    • Trained on 4-bit base model

    Original model card: June Lee's Wizard Vicuna 13B

    Chat & support: my new Discord server

    Want to contribute? TheBloke's Patreon page

    # Wizard-Vicuna-13B-HF

    This is a float16 HF format repo for junelee's wizard-vicuna 13B .

    June Lee's repo was also HF format. The reason I've made this is that the original repo was in float32, meaning it required 52GB disk space, VRAM and RAM.

    This model was converted to float16 to make it easier to load and manage.

    Repositories available

    Discord

    For further support, and discussions on these models and AI in general, join us at:

    TheBloke AI's Discord server

    Thanks, and how to contribute.

    Thanks to the chirper.ai team!

    I've had a lot of people ask if they can contribute. I enjoy providing models and helping people, and would love to be able to spend even more time doing it, as well as expanding into new projects like fine tuning/training.

    If you're able and willing to contribute it will be most gratefully received and will help me to keep providing more models, and to start work on new AI projects.

    Donaters will get priority support on any and all AI/LLM/model questions and requests, access to a private Discord room, plus other benefits.

    Patreon special mentions : Aemon Algiz, Dmitriy Samsonov, Nathan LeClaire, Trenton Dambrowitz, Mano Prime, David Flickinger, vamX, Nikolai Manek, senxiiz, Khalefa Al-Ahmad, Illia Dulskyi, Jonathan Leane, Talal Aujan, V. Lukas, Joseph William Delisle, Pyrater, Oscar Rangel, Lone Striker, Luke Pendergrass, Eugene Pentland, Sebastain Graf, Johann-Peter Hartman.

    Thank you to all my generous patrons and donaters!

    Original WizardVicuna-13B model card

    Github page: https://github.com/melodysdreamj/WizardVicunaLM

    WizardVicunaLM

    Wizard's dataset + ChatGPT's conversation extension + Vicuna's tuning method

    I am a big fan of the ideas behind WizardLM and VicunaLM. I particularly like the idea of WizardLM handling the dataset itself more deeply and broadly, as well as VicunaLM overcoming the limitations of single-turn conversations by introducing multi-round conversations. As a result, I combined these two ideas to create WizardVicunaLM. This project is highly experimental and designed for proof of concept, not for actual usage.

    Benchmark

    Approximately 7% performance improvement over VicunaLM

    Detail

    The questions presented here are not from rigorous tests, but rather, I asked a few questions and requested GPT-4 to score them. The models compared were ChatGPT 3.5, WizardVicunaLM, VicunaLM, and WizardLM, in that order.

    gpt3.5 wizard-vicuna-13b vicuna-13b wizard-7b link
    Q1 95 90 85 88 link
    Q2 95 97 90 89 link
    Q3 85 90 80 65 link
    Q4 90 85 80 75 link
    Q5 90 85 80 75 link
    Q6 92 85 87 88 link
    Q7 95 90 85 92 link
    Q8 90 85 75 70 link
    Q9 92 85 70 60 link
    Q10 90 80 75 85 link
    Q11 90 85 75 65 link
    Q12 85 90 80 88 link
    Q13 90 95 88 85 link
    Q14 94 89 90 91 link
    Q15 90 85 88 87 link
    91 88 82 80

    Principle

    We adopted the approach of WizardLM, which is to extend a single problem more in-depth. However, instead of using individual instructions, we expanded it using Vicuna's conversation format and applied Vicuna's fine-tuning techniques.

    Turning a single command into a rich conversation is what we've done here .

    After creating the training data, I later trained it according to the Vicuna v1.1 training method .

    Detailed Method

    First, we explore and expand various areas in the same topic using the 7K conversations created by WizardLM. However, we made it in a continuous conversation format instead of the instruction format. That is, it starts with WizardLM's instruction, and then expands into various areas in one conversation using ChatGPT 3.5.

    After that, we applied the following model using Vicuna's fine-tuning format.

    Training Process

    Trained with 8 A100 GPUs for 35 hours.

    Weights

    You can see the dataset we used for training and the 13b model in the huggingface.

    Conclusion

    If we extend the conversation to gpt4 32K, we can expect a dramatic improvement, as we can generate 8x more, more accurate and richer conversations.

    License

    The model is licensed under the LLaMA model, and the dataset is licensed under the terms of OpenAI because it uses ChatGPT. Everything else is free.

    Author

    JUNE LEE - He is active in Songdo Artificial Intelligence Study and GDG Songdo.