run.sh 4.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105
  1. export CUDA_VISIBLE_DEVICES=0
  2. cosyvoice_path=/workspace/CosyVoice
  3. export PYTHONPATH=${cosyvoice_path}:$PYTHONPATH
  4. export PYTHONPATH=${cosyvoice_path}/third_party/Matcha-TTS:$PYTHONPATH
  5. stage=$1
  6. stop_stage=$2
  7. huggingface_model_local_dir=./cosyvoice2_llm
  8. model_scope_model_local_dir=./CosyVoice2-0.5B
  9. trt_dtype=bfloat16
  10. trt_weights_dir=./trt_weights_${trt_dtype}
  11. trt_engines_dir=./trt_engines_${trt_dtype}
  12. model_repo=./model_repo_cosyvoice2
  13. if [ $stage -le -1 ] && [ $stop_stage -ge -1 ]; then
  14. echo "Cloning CosyVoice"
  15. git clone --recursive https://github.com/FunAudioLLM/CosyVoice.git $cosyvoice_path
  16. cd $cosyvoice_path
  17. git submodule update --init --recursive
  18. cd runtime/triton_trtllm
  19. fi
  20. if [ $stage -le 0 ] && [ $stop_stage -ge 0 ]; then
  21. echo "Downloading CosyVoice2-0.5B"
  22. huggingface-cli download --local-dir $huggingface_model_local_dir yuekai/cosyvoice2_llm
  23. modelscope download --model iic/CosyVoice2-0.5B --local_dir $model_scope_model_local_dir
  24. fi
  25. if [ $stage -le 1 ] && [ $stop_stage -ge 1 ]; then
  26. echo "Converting checkpoint to TensorRT weights"
  27. python3 scripts/convert_checkpoint.py --model_dir $huggingface_model_local_dir \
  28. --output_dir $trt_weights_dir \
  29. --dtype $trt_dtype || exit 1
  30. echo "Building TensorRT engines"
  31. trtllm-build --checkpoint_dir $trt_weights_dir \
  32. --output_dir $trt_engines_dir \
  33. --max_batch_size 16 \
  34. --max_num_tokens 32768 \
  35. --gemm_plugin $trt_dtype || exit 1
  36. echo "Testing TensorRT engines"
  37. python3 ./scripts/test_llm.py --input_text "你好,请问你叫什么?" \
  38. --tokenizer_dir $huggingface_model_local_dir \
  39. --top_k 50 --top_p 0.95 --temperature 0.8 \
  40. --engine_dir=$trt_engines_dir || exit 1
  41. fi
  42. if [ $stage -le 2 ] && [ $stop_stage -ge 2 ]; then
  43. echo "Creating model repository"
  44. rm -rf $model_repo
  45. mkdir -p $model_repo
  46. cosyvoice2_dir="cosyvoice2"
  47. cp -r ./model_repo/${cosyvoice2_dir} $model_repo
  48. cp -r ./model_repo/audio_tokenizer $model_repo
  49. cp -r ./model_repo/tensorrt_llm $model_repo
  50. cp -r ./model_repo/token2wav $model_repo
  51. ENGINE_PATH=$trt_engines_dir
  52. MAX_QUEUE_DELAY_MICROSECONDS=0
  53. MODEL_DIR=$model_scope_model_local_dir
  54. LLM_TOKENIZER_DIR=$huggingface_model_local_dir
  55. BLS_INSTANCE_NUM=4
  56. TRITON_MAX_BATCH_SIZE=16
  57. DECOUPLED_MODE=False
  58. python3 scripts/fill_template.py -i ${model_repo}/token2wav/config.pbtxt model_dir:${MODEL_DIR},triton_max_batch_size:${TRITON_MAX_BATCH_SIZE},max_queue_delay_microseconds:${MAX_QUEUE_DELAY_MICROSECONDS}
  59. python3 scripts/fill_template.py -i ${model_repo}/audio_tokenizer/config.pbtxt model_dir:${MODEL_DIR},triton_max_batch_size:${TRITON_MAX_BATCH_SIZE},max_queue_delay_microseconds:${MAX_QUEUE_DELAY_MICROSECONDS}
  60. python3 scripts/fill_template.py -i ${model_repo}/${cosyvoice2_dir}/config.pbtxt model_dir:${MODEL_DIR},bls_instance_num:${BLS_INSTANCE_NUM},llm_tokenizer_dir:${LLM_TOKENIZER_DIR},triton_max_batch_size:${TRITON_MAX_BATCH_SIZE},decoupled_mode:${DECOUPLED_MODE},max_queue_delay_microseconds:${MAX_QUEUE_DELAY_MICROSECONDS}
  61. python3 scripts/fill_template.py -i ${model_repo}/tensorrt_llm/config.pbtxt triton_backend:tensorrtllm,triton_max_batch_size:${TRITON_MAX_BATCH_SIZE},decoupled_mode:${DECOUPLED_MODE},max_beam_width:1,engine_dir:${ENGINE_PATH},max_tokens_in_paged_kv_cache:2560,max_attention_window_size:2560,kv_cache_free_gpu_mem_fraction:0.5,exclude_input_in_output:True,enable_kv_cache_reuse:False,batching_strategy:inflight_fused_batching,max_queue_delay_microseconds:${MAX_QUEUE_DELAY_MICROSECONDS},encoder_input_features_data_type:TYPE_FP16,logits_datatype:TYPE_FP32
  62. fi
  63. if [ $stage -le 3 ] && [ $stop_stage -ge 3 ]; then
  64. echo "Starting Triton server"
  65. tritonserver --model-repository $model_repo
  66. fi
  67. if [ $stage -le 4 ] && [ $stop_stage -ge 4 ]; then
  68. echo "Single request test http"
  69. python3 client_http.py \
  70. --reference-audio ./assets/prompt_audio.wav \
  71. --reference-text "吃燕窝就选燕之屋,本节目由26年专注高品质燕窝的燕之屋冠名播出。豆奶牛奶换着喝,营养更均衡,本节目由豆本豆豆奶特约播出。" \
  72. --target-text "身临其境,换新体验。塑造开源语音合成新范式,让智能语音更自然。" \
  73. --model-name cosyvoice2
  74. fi
  75. if [ $stage -le 5 ] && [ $stop_stage -ge 5 ]; then
  76. echo "Running benchmark client grpc"
  77. num_task=4
  78. # set mode=streaming, when decoupled=True
  79. # set mode=offline, when decoupled=False
  80. mode=offline
  81. python3 client_grpc.py \
  82. --server-addr localhost \
  83. --model-name cosyvoice2 \
  84. --num-tasks $num_task \
  85. --mode $mode \
  86. --huggingface-dataset yuekai/seed_tts_cosy2 \
  87. --log-dir ./log_concurrent_tasks_${num_task}_${mode}_bls_4_${trt_dtype}
  88. fi