Source code for sparknlp.annotator.seq2seq.auto_gguf_model

#  Copyright 2017-2023 John Snow Labs
#
#  Licensed under the Apache License, Version 2.0 (the "License");
#  you may not use this file except in compliance with the License.
#  You may obtain a copy of the License at
#
#     http://www.apache.org/licenses/LICENSE-2.0
#
#  Unless required by applicable law or agreed to in writing, software
#  distributed under the License is distributed on an "AS IS" BASIS,
#  WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
#  See the License for the specific language governing permissions and
#  limitations under the License.
"""Contains classes for the AutoGGUFModel."""
from typing import List, Dict

from sparknlp.common import *


[docs]class AutoGGUFModel(AnnotatorModel, HasBatchedAnnotate, HasLlamaCppProperties): """ Annotator that uses the llama.cpp library to generate text completions with large language models. For settable parameters, and their explanations, see the parameters of this class and refer to the llama.cpp documentation of `server.cpp <https://github.com/ggerganov/llama.cpp/tree/7d5e8777ae1d21af99d4f95be10db4870720da91/examples/server>`__ for more information. If the parameters are not set, the annotator will default to use the parameters provided by the model. Pretrained models can be loaded with :meth:`.pretrained` of the companion object: >>> auto_gguf_model = AutoGGUFModel.pretrained() \\ ... .setInputCols(["document"]) \\ ... .setOutputCol("completions") The default model is ``"phi3.5_mini_4k_instruct_q4_gguf"``, if no name is provided. For extended examples of usage, see the `AutoGGUFModelTest <https://github.com/JohnSnowLabs/spark-nlp/tree/master/src/test/scala/com/johnsnowlabs/nlp/annotators/seq2seq/AutoGGUFModelTest.scala>`__ and the `example notebook <https://github.com/JohnSnowLabs/spark-nlp/tree/master/examples/python/llama.cpp/llama.cpp_in_Spark_NLP_AutoGGUFModel.ipynb>`__. For available pretrained models please see the `Models Hub <https://sparknlp.org/models>`__. ====================== ====================== Input Annotation types Output Annotation type ====================== ====================== ``DOCUMENT`` ``DOCUMENT`` ====================== ====================== Parameters ---------- nThreads Set the number of threads to use during generation nThreadsDraft Set the number of threads to use during draft generation nThreadsBatch Set the number of threads to use during batch and prompt processing nThreadsBatchDraft Set the number of threads to use during batch and prompt processing nCtx Set the size of the prompt context nBatch Set the logical batch size for prompt processing (must be >=32 to use BLAS) nUbatch Set the physical batch size for prompt processing (must be >=32 to use BLAS) nDraft Set the number of tokens to draft for speculative decoding nChunks Set the maximal number of chunks to process nSequences Set the number of sequences to decode pSplit Set the speculative decoding split probability nGpuLayers Set the number of layers to store in VRAM (-1 - use default) nGpuLayersDraft Set the number of layers to store in VRAM for the draft model (-1 - use default) gpuSplitMode Set how to split the model across GPUs mainGpu Set the main GPU that is used for scratch and small tensors. tensorSplit Set how split tensors should be distributed across GPUs grpAttnN Set the group-attention factor grpAttnW Set the group-attention width ropeFreqBase Set the RoPE base frequency, used by NTK-aware scaling ropeFreqScale Set the RoPE frequency scaling factor, expands context by a factor of 1/N yarnExtFactor Set the YaRN extrapolation mix factor yarnAttnFactor Set the YaRN scale sqrt(t) or attention magnitude yarnBetaFast Set the YaRN low correction dim or beta yarnBetaSlow Set the YaRN high correction dim or alpha yarnOrigCtx Set the YaRN original context size of model defragmentationThreshold Set the KV cache defragmentation threshold numaStrategy Set optimization strategies that help on some NUMA systems (if available) ropeScalingType Set the RoPE frequency scaling method, defaults to linear unless specified by the model poolingType Set the pooling type for embeddings, use model default if unspecified modelDraft Set the draft model for speculative decoding modelAlias Set a model alias lookupCacheStaticFilePath Set path to static lookup cache to use for lookup decoding (not updated by generation) lookupCacheDynamicFilePath Set path to dynamic lookup cache to use for lookup decoding (updated by generation) embedding Whether to load model with embedding support flashAttention Whether to enable Flash Attention inputPrefixBos Whether to add prefix BOS to user inputs, preceding the `--in-prefix` string useMmap Whether to use memory-map model (faster load but may increase pageouts if not using mlock) useMlock Whether to force the system to keep model in RAM rather than swapping or compressing noKvOffload Whether to disable KV offload systemPrompt Set a system prompt to use chatTemplate The chat template to use inputPrefix Set the prompt to start generation with inputSuffix Set a suffix for infilling cachePrompt Whether to remember the prompt to avoid reprocessing it nPredict Set the number of tokens to predict topK Set top-k sampling topP Set top-p sampling minP Set min-p sampling tfsZ Set tail free sampling, parameter z typicalP Set locally typical sampling, parameter p temperature Set the temperature dynatempRange Set the dynamic temperature range dynatempExponent Set the dynamic temperature exponent repeatLastN Set the last n tokens to consider for penalties repeatPenalty Set the penalty of repeated sequences of tokens frequencyPenalty Set the repetition alpha frequency penalty presencePenalty Set the repetition alpha presence penalty miroStat Set MiroStat sampling strategies. mirostatTau Set the MiroStat target entropy, parameter tau mirostatEta Set the MiroStat learning rate, parameter eta penalizeNl Whether to penalize newline tokens nKeep Set the number of tokens to keep from the initial prompt seed Set the RNG seed nProbs Set the amount top tokens probabilities to output if greater than 0. minKeep Set the amount of tokens the samplers should return at least (0 = disabled) grammar Set BNF-like grammar to constrain generations penaltyPrompt Override which part of the prompt is penalized for repetition. ignoreEos Set whether to ignore end of stream token and continue generating (implies --logit-bias 2-inf) disableTokenIds Set the token ids to disable in the completion stopStrings Set strings upon seeing which token generation is stopped samplers Set which samplers to use for token generation in the given order useChatTemplate Set whether or not generate should apply a chat template Notes ----- To use GPU inference with this annotator, make sure to use the Spark NLP GPU package and set the number of GPU layers with the `setNGpuLayers` method. When using larger models, we recommend adjusting GPU usage with `setNCtx` and `setNGpuLayers` according to your hardware to avoid out-of-memory errors. Examples -------- >>> import sparknlp >>> from sparknlp.base import * >>> from sparknlp.annotator import * >>> from pyspark.ml import Pipeline >>> document = DocumentAssembler() \\ ... .setInputCol("text") \\ ... .setOutputCol("document") >>> autoGGUFModel = AutoGGUFModel.pretrained() \\ ... .setInputCols(["document"]) \\ ... .setOutputCol("completions") \\ ... .setBatchSize(4) \\ ... .setNPredict(20) \\ ... .setNGpuLayers(99) \\ ... .setTemperature(0.4) \\ ... .setTopK(40) \\ ... .setTopP(0.9) \\ ... .setPenalizeNl(True) >>> pipeline = Pipeline().setStages([document, autoGGUFModel]) >>> data = spark.createDataFrame([["Hello, I am a"]]).toDF("text") >>> result = pipeline.fit(data).transform(data) >>> result.select("completions").show(truncate = False) +-----------------------------------------------------------------------------------------------------------------------------------+ |completions | +-----------------------------------------------------------------------------------------------------------------------------------+ |[{document, 0, 78, new user. I am currently working on a project and I need to create a list of , {prompt -> Hello, I am a}, []}]| +-----------------------------------------------------------------------------------------------------------------------------------+ """ name = "AutoGGUFModel" inputAnnotatorTypes = [AnnotatorType.DOCUMENT] outputAnnotatorType = AnnotatorType.DOCUMENT @keyword_only def __init__(self, classname="com.johnsnowlabs.nlp.annotators.seq2seq.AutoGGUFModel", java_model=None): super(AutoGGUFModel, self).__init__( classname=classname, java_model=java_model ) self._setDefault( useChatTemplate=True, nCtx=4096, nBatch=512, embedding=False, nPredict=100 )
[docs] @staticmethod def loadSavedModel(folder, spark_session): """Loads a locally saved model. Parameters ---------- folder : str Folder of the saved model spark_session : pyspark.sql.SparkSession The current SparkSession Returns ------- AutoGGUFModel The restored model """ from sparknlp.internal import _AutoGGUFLoader jModel = _AutoGGUFLoader(folder, spark_session._jsparkSession)._java_obj return AutoGGUFModel(java_model=jModel)
[docs] @staticmethod def pretrained(name="phi3.5_mini_4k_instruct_q4_gguf", lang="en", remote_loc=None): """Downloads and loads a pretrained model. Parameters ---------- name : str, optional Name of the pretrained model, by default "phi3.5_mini_4k_instruct_q4_gguf" lang : str, optional Language of the pretrained model, by default "en" remote_loc : str, optional Optional remote address of the resource, by default None. Will use Spark NLPs repositories otherwise. Returns ------- AutoGGUFModel The restored model """ from sparknlp.pretrained import ResourceDownloader return ResourceDownloader.downloadModel(AutoGGUFModel, name, lang, remote_loc)