Generate text with customization
Source https://github.com/NVIDIA/TensorRT-LLM/tree/main/examples/llm-api/llm_inference_customize.py.
1### Generate text with customization
2import tempfile
3
4from tensorrt_llm.llmapi import LLM, BuildConfig, KvCacheConfig, SamplingParams
5
6
7def main():
8 # The end user can customize the build configuration with the build_config class and other arguments borrowed from the lower-level APIs
9 build_config = BuildConfig()
10 build_config.max_batch_size = 128
11 build_config.max_num_tokens = 2048
12
13 build_config.max_beam_width = 4
14
15 # Model could accept HF model name or a path to local HF model.
16
17 llm = LLM(
18 model="TinyLlama/TinyLlama-1.1B-Chat-v1.0",
19 build_config=build_config,
20 kv_cache_config=KvCacheConfig(
21 free_gpu_memory_fraction=0.8
22 ), # Similar to `build_config`, you can also customize the runtime configuration with the `kv_cache_config`, `runtime_config`, `peft_cache_config` or \
23 # other arguments borrowed from the lower-level APIs.
24 )
25
26 # You can save the engine to disk and load it back later, the LLM class can accept either a HF model or a TRT-LLM engine.
27 llm.save(tempfile.mkdtemp())
28
29 # Sample prompts.
30 prompts = [
31 "Hello, my name is",
32 "The president of the United States is",
33 "The capital of France is",
34 "The future of AI is",
35 ]
36
37 # With SamplingParams, you can customize the sampling strategy, such as beam search, temperature, and so on.
38 sampling_params = SamplingParams(temperature=0.8, top_p=0.95, beam_width=4)
39
40 for output in llm.generate(prompts, sampling_params):
41 print(
42 f"Prompt: {output.prompt!r}, Generated text: {output.outputs[0].text!r}"
43 )
44
45 # Got output like
46 # Prompt: 'Hello, my name is', Generated text: '\n\nJane Smith. I am a student pursuing my degree in Computer Science at [university]. I enjoy learning new things, especially technology and programming'
47 # Prompt: 'The president of the United States is', Generated text: 'likely to nominate a new Supreme Court justice to fill the seat vacated by the death of Antonin Scalia. The Senate should vote to confirm the'
48 # Prompt: 'The capital of France is', Generated text: 'Paris.'
49 # Prompt: 'The future of AI is', Generated text: 'an exciting time for us. We are constantly researching, developing, and improving our platform to create the most advanced and efficient model available. We are'
50
51
52if __name__ == '__main__':
53 main()