신청 절차
API를 사용하려면 먼저 Producer Audios Generation API 해당 페이지에서 서비스를 신청해야 합니다. 페이지에 들어가면 「Acquire」 버튼을 클릭합니다, 아래 그림과 같이:
로그인 또는 등록이 되어 있지 않으면 자동으로 로그인 페이지로 이동하여 등록 및 로그인을 초대합니다. 로그인 및 등록 후에는 자동으로 현재 페이지로 돌아옵니다.
첫 신청 시 무료 한도가 제공되어 해당 API를 무료로 사용할 수 있습니다.
기본 사용
생각하는 곡을 입력할 수 있으며, 예를 들어 크리스마스에 대한 곡을 생성하고 싶다면a song for Christmas를 입력하면 됩니다, 아래 그림과 같이:

accept:어떤 형식의 응답 결과를 받고 싶은지, 여기서는application/json으로 JSON 형식으로 입력합니다.authorization:API 호출을 위한 키, 신청 후 직접 드롭다운에서 선택할 수 있습니다.
action:이번 음악 생성 작업의 행동, 곡 생성을 위해서는generate입니다.model:곡 생성을 위해 사용하는 모델, 현재 주요 모델은: FUZZ-2.0 Pro, FUZZ-2.0, FUZZ-2.0 Raw, FUZZ-1.1 Pro, FUZZ-1.0 Pro, FUZZ-1.0, FUZZ-1.1, FUZZ-0.8입니다.lyric:곡의 가사 내용입니다.custom:곡을 사용자 정의 방식으로 생성할지 여부입니다.prompt:영감 모드에서의 힌트 단어입니다.title:곡 제목 정보입니다.audio_id:참조 곡 ID, 이어쓰기/복사 등의 작업에 사용됩니다.continue_at:지정된 초에서 곡을 이어쓰기 시작합니다.replace_section_start/replace_section_end:대체 구간의 시작 및 종료 시간, 단위는 초입니다.lyrics_strength:가사 강도, 가사가 오디오 생성에 미치는 영향을 나타내며, 0-1 사이의 선택 가능, 기본값은 0.7입니다.sound_strength:오디오 힌트 단어 강도, 0.2-1 사이의 선택 가능, 기본값은 0.7입니다.cover_strength:커버 강도 0.2-1 사이, 기본값은 1입니다.weirdness:스타일 특이도, 0-1 사이의 선택 가능, 기본값은 0.5입니다.callback_url:결과를 회신받을 URL입니다.instrumental:가사 없는 모드인지 여부입니다.

success,현재 음악 생성 작업의 상태입니다.data,이번 음악 작업의 결과입니다.id,현재 음악 생성 작업의 ID입니다.sound,현재 음악 생성 작업의 힌트 단어입니다.seed,현재 음악 생성 작업의 시드 값입니다.audio_url,현재 음악 생성 작업의 오디오 링크입니다.image_url,현재 음악 생성 작업의 커버 링크입니다.image_id,현재 음악 생성 작업의 커버 ID입니다.state,현재 음악 생성 작업의 상태입니다.duration,현재 음악의 길이 정보입니다.progress,현재 음악 작업의 진행 값입니다.model,현재 음악 생성 작업에 사용된 모델 정보입니다.lyric,현재 음악 생성 작업의 가사 정보입니다.
data에서 음악 링크 주소를 통해 생성된 Producer 음악을 가져올 수 있습니다.
또한, 해당 연동 코드를 생성하고 싶다면 직접 복사하여 생성할 수 있습니다, 예를 들어 CURL의 코드는 다음과 같습니다:
사용자 정의 생성
가사를 사용자 정의로 생성하고 싶다면 가사를 입력할 수 있습니다: 이때lyric 필드에는 다음과 같은 내용을 전달할 수 있습니다:
- lyric:가사 텍스트
- custom:
true로 입력하여 사용자 정의 생성을 나타내며, 이 매개변수의 기본값은 false로prompt생성을 의미합니다. - title:곡의 제목입니다. 填写样例如下:


번안 곡
이미 생성된 곡을 번안하고 싶다면, 위에서 생성된 곡을 입력하여 번안할 수 있습니다. 다음으로 우리는 가사와 제목에 따라 곡을 사용자 정의하여 생성해야 합니다. 자신이 업로드한 곡을 계속 번안하고 싶다면, 매개변수action을 upload_cover로 설정하고, 계속 번안할 사용자 정의 업로드 곡 ID를 입력해야 합니다. 곡 ID는 Producer Upload API를 사용하여 얻을 수 있으며, 아래 그림과 같이 지정할 수 있습니다:

- action: 이번 곡 작업의 행동, 현재 지원되는 것은: generate, cover, extend, upload_cover, upload_extend, replace_section, swap_vocals, swap_instrumentals, variation, 이번 번안에서는
cover매개변수를 사용합니다. - lyric: 가사 텍스트
- title: 곡의 제목.
- custom: 사용자 정의 모드로 생성할지 여부, 기본값은 false입니다.
- audio_id: 번안할 곡의 곡 ID.


노래 이어쓰기
노래를 이어 쓰고 싶다면,action 매개변수의 값을 extend로 설정해야 하며, 그 다음 가사, 제목, 스타일에 따라 노래를 맞춤 생성해야 합니다.
자신이 업로드한 노래를 계속 이어 쓰고 싶다면, action 매개변수를 upload_extend로 설정하고, 이어 쓸 사용자 정의 업로드 노래 ID를 입력해야 합니다. 노래 ID는 Producer Upload API를 사용하여 얻을 수 있으며, 아래 그림과 같습니다:



음악 변환
이전 곡의 seed 값을 기반으로 유사한 효과의 새로운 음악을 생성하고 싶다면,action 매개변수의 값을 variation으로 설정해야 하며, 그 다음 유사한 효과의 새로운 음악을 맞춤 생성할 수 있습니다.
작성 예시는 다음과 같습니다:


교체 구간
노래의 구간을 교체하고 싶다면,action 매개변수 값을 replace_section으로 설정해야 하며, 그 다음 가사와 제목에 따라 노래를 사용자 정의 생성해야 합니다.
자신이 업로드한 노래를 계속 교체하고 싶다면, 매개변수 action을 upload_replace_section으로 설정하고, 계속 작성할 사용자 정의 업로드 노래 ID를 입력해야 합니다. 노래 ID는 Producer Upload API를 사용하여 가져올 수 있으며, 아래 그림과 같습니다:



반주 변환
공식 반주 변환 작업을 사용하고 싶다면action 매개변수 값을 swap_instrumentals로 설정하면 됩니다. 다음으로 우리는 가사와 제목에 따라 곡을 사용자 정의 생성할 것입니다.
작성 예시는 다음과 같습니다:


보컬 변환
공식 보컬 변환 작업을 사용하고 싶다면action 매개변수 값을 swap_vocals로 설정하면 됩니다. 다음으로 우리는 가사, 제목, 스타일에 따라 곡을 사용자 정의 생성할 것입니다.
작성 예시는 다음과 같습니다:


가사와 곡 분리
공식적인 가사와 곡 분리 작업을 사용하고 싶다면action 매개변수 값을 stems로 설정하면 됩니다. 다음으로 우리는 곡 ID에 따라 가사와 곡을 분리해야 합니다.
작성 예시는 다음과 같습니다:


비동기 콜백
Producer Audios Generation API의 생성 시간이 때때로 상대적으로 길어질 수 있으므로, API가 오랜 시간 동안 응답하지 않으면 HTTP 요청이 연결을 유지하여 추가 시스템 자원 소모를 초래할 수 있습니다. 따라서 이 API는 비동기 콜백 지원도 제공합니다. 전체 프로세스는 클라이언트가 요청을 시작할 때 추가로callback_url 필드를 지정하는 것입니다. 클라이언트가 API 요청을 시작한 후, API는 즉시 결과를 반환하며, 현재 작업 ID를 나타내는 task_id 필드 정보를 포함합니다. 작업이 완료되면 생성된 작업 결과가 POST JSON 형식으로 클라이언트가 지정한 callback_url로 전송되며, 여기에도 task_id 필드가 포함되어 있어 작업 결과를 ID로 연결할 수 있습니다.
아래 예제를 통해 구체적으로 어떻게 작업하는지 알아보겠습니다.
먼저, Webhook 콜백은 HTTP 요청을 수신할 수 있는 서비스로, 개발자는 자신이 구축한 HTTP 서버의 URL로 교체해야 합니다. 여기서는 편리한 시연을 위해 공개 Webhook 샘플 사이트 https://webhook.site/를 사용합니다. 해당 사이트를 열면 Webhook URL을 얻을 수 있습니다. 아래와 같이:
이 URL을 복사하여 Webhook으로 사용할 수 있으며, 여기서의 샘플은 https://webhook.site/#!/view/0d73431d-f833-4be4-9276-b6e1690d55c1입니다.
다음으로, callback_url 필드를 위의 Webhook URL로 설정하고, 해당 매개변수를 입력합니다. 구체적인 내용은 아래와 같습니다:

내용은 다음과 같습니다:
task_id 필드가 있으며, 다른 필드들은 위와 유사합니다. 이 필드를 통해 작업의 연관성을 실현할 수 있습니다.
오류 처리
API를 호출할 때 오류가 발생하면, API는 해당 오류 코드와 정보를 반환합니다. 예를 들어:400 token_mismatched:잘못된 요청, 누락되었거나 잘못된 매개변수 때문일 수 있습니다.400 api_not_implemented:잘못된 요청, 누락되었거나 잘못된 매개변수 때문일 수 있습니다.401 invalid_token:권한 없음, 잘못되었거나 누락된 인증 토큰입니다.429 too_many_requests:요청이 너무 많습니다. 비율 한도를 초과했습니다.500 api_error:내부 서버 오류, 서버에서 문제가 발생했습니다.

