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()