앱에 적합한 AI/ML 솔루션 찾기

이 가이드는 Google의 생성형 인공지능 및 머신러닝 (AI/ML) 솔루션을 애플리케이션에 통합하는 데 도움이 되도록 설계되었습니다. 다양한 인공지능 및 머신러닝 솔루션을 살펴보고 필요에 가장 적합한 솔루션을 선택하는 데 도움이 되는 안내를 제공합니다. 이 문서의 목표는 요구사항과 사용 사례에 중점을 두어 어떤 도구를 사용해야 하는지, 그 이유는 무엇인지 결정하는 데 도움을 주는 것입니다.

특정 요구사항에 가장 적합한 AI/ML 솔루션을 선택하는 데 도움이 되도록 이 문서에는 솔루션 가이드가 포함되어 있습니다. 프로젝트의 목표와 제약 조건에 관한 일련의 질문에 답하면 가이드에서 가장 적합한 도구와 기술을 안내합니다.

이 가이드는 앱에 가장 적합한 AI 솔루션을 선택하는 데 도움이 됩니다. 데이터 유형 (텍스트, 이미지, 오디오, 동영상), 작업의 복잡성(간단한 요약부터 전문 지식이 필요한 복잡한 작업), 데이터 크기 (짧은 입력 대 대규모 문서) 등의 요소를 고려하세요. 이를 통해 기기에서 Gemini Nano를 사용할지 아니면 Firebase의 클라우드 기반 AI (Gemini Flash, Gemini Pro 또는 Imagen)를 사용할지 결정할 수 있습니다.

생성형 AI 사용 사례의 결정 흐름도 기준에는 모달리티(텍스트, 이미지 대 오디오, 동영상, 이미지 생성), 복잡성(요약, 다시 쓰기 대 도메인 지식), 컨텍스트 윈도우(짧은 입력/출력 대 광범위한 문서/미디어)가 포함되며, 이에 따라 온디바이스 생성형 AI (Gemini Nano) 또는 Firebase AI Logic (Gemini Flash, Pro, Imagen)이 사용됩니다.
그림 1: Android 앱에 적합한 AI/ML 솔루션을 찾는 데 도움이 되는 개략적인 솔루션 가이드를 나타냅니다. AI 및 ML 옵션에 관한 자세한 내용은 이 문서의 뒷부분에 나오는 솔루션 가이드를 참고하세요.

온디바이스 추론의 강력한 기능 활용

Android 앱에 AI 및 ML 기능을 추가할 때 기기에서 또는 클라우드를 사용하여 기능을 제공하는 다양한 방법을 선택할 수 있습니다.

Gemini Nano와 같은 온디바이스 솔루션은 추가 비용 없이 결과를 제공하고, 사용자 개인 정보 보호를 강화하며, 입력 데이터가 로컬로 처리되므로 안정적인 오프라인 기능을 제공합니다. 이러한 이점은 메시지 요약과 같은 특정 사용 사례에 매우 중요할 수 있으므로 적절한 솔루션을 선택할 때 온디바이스를 우선시해야 합니다.

Gemini Nano를 사용하면 Android 기반 기기에서 직접 추론을 실행할 수 있습니다. 텍스트, 이미지 또는 오디오로 작업하는 경우 ML Kit의 생성형 AI API를 사용하여 바로 사용할 수 있는 솔루션을 시작하세요. ML Kit GenAI API는 Gemini Nano를 기반으로 하며 특정 온디바이스 작업에 맞게 파인 튜닝되어 있습니다. ML Kit 생성형 AI API는 높은 수준의 인터페이스와 확장성으로 인해 앱의 프로덕션에 적합합니다. 이러한 API를 사용하면 텍스트를 요약, 교정, 재작성하고, 이미지 설명을 생성하고, 음성 인식을 실행하는 사용 사례를 구현할 수 있습니다.

ML Kit GenAI API에서 제공하는 기본 사용 사례를 넘어선 기능을 사용하려면 Gemini Nano 실험용 액세스를 고려하세요. Gemini Nano 실험용 액세스를 사용하면 Gemini Nano의 맞춤 프롬프트에 더 직접적으로 액세스할 수 있습니다.

기존 머신러닝 작업의 경우 자체 맞춤 모델을 유연하게 구현할 수 있습니다. Google은 ML Kit, MediaPipe, LiteRT, Google Play 전송 기능과 같은 강력한 도구를 제공하여 개발 프로세스를 간소화합니다.

고도로 전문화된 솔루션이 필요한 애플리케이션의 경우 Gemma와 같은 자체 맞춤 모델이나 특정 사용 사례에 맞게 조정된 다른 모델을 사용할 수 있습니다. 최적화된 성능을 위해 사전 설계된 모델 아키텍처를 제공하는 LiteRT를 사용하여 사용자의 기기에서 직접 모델을 실행하세요.

온디바이스 모델과 클라우드 모델을 모두 활용하여 하이브리드 솔루션을 빌드하는 것도 고려해 볼 수 있습니다.

모바일 앱은 일반적으로 채팅 대화나 블로그 게시물과 같은 작은 텍스트 데이터에 로컬 모델을 활용합니다. 하지만 PDF와 같은 대규모 데이터 소스나 추가 지식이 필요한 경우에는 더 강력한 Gemini 모델이 있는 클라우드 기반 솔루션이 필요할 수 있습니다.

고급 Gemini 모델 통합

Android 개발자는 Firebase AI Logic SDK를 사용하여 강력한 Gemini Pro, Gemini Flash, Imagen 모델을 비롯한 Google의 고급 생성형 AI 기능을 애플리케이션에 통합할 수 있습니다. 이 SDK는 대규모 데이터 요구사항을 위해 설계되었으며, 이러한 고성능 멀티모달 AI 모델에 대한 액세스를 지원하여 확장된 기능과 적응성을 제공합니다.

Firebase AI Logic SDK를 사용하면 개발자가 최소한의 노력으로 Google의 AI 모델을 클라이언트 측에서 호출할 수 있습니다. 이러한 모델(예: Gemini Pro, Gemini Flash)은 클라우드에서 추론을 실행하며 Android 앱이 이미지, 오디오, 동영상, 텍스트를 비롯한 다양한 입력을 처리할 수 있도록 지원합니다. Gemini Pro는 복잡한 문제에 대한 추론과 광범위한 데이터 분석에 탁월하며, Gemini Flash 시리즈는 대부분의 작업에 충분한 속도와 컨텍스트 윈도우를 제공합니다.

기존 머신러닝을 사용해야 하는 경우

생성형 AI는 텍스트, 이미지, 코드와 같은 콘텐츠를 만들고 수정하는 데 유용하지만, 많은 실제 문제는 기존 머신러닝 (ML) 기법을 사용하여 해결하는 것이 더 좋습니다. 이러한 기존 방법은 예측, 분류, 감지, 기존 데이터 내 패턴 이해와 관련된 작업에서 뛰어난 성능을 발휘하며, 생성형 모델보다 효율성이 높고, 컴퓨팅 비용이 낮으며, 구현이 더 간단한 경우가 많습니다.

기존 ML 프레임워크는 완전히 새로운 출력을 생성하는 대신 입력을 분석하거나, 특징을 식별하거나, 학습된 패턴을 기반으로 예측하는 데 중점을 둔 애플리케이션을 위한 강력하고 최적화된 실용적인 솔루션을 제공하는 경우가 많습니다. Google의 ML Kit, LiteRT, MediaPipe와 같은 도구는 특히 모바일 및 에지 컴퓨팅 환경에서 이러한 생성형이 아닌 사용 사례에 맞게 조정된 강력한 기능을 제공합니다.

ML Kit으로 머신러닝 통합 시작하기

ML Kit는 사전 ML 전문 지식이 필요 없는 일반적인 머신러닝 작업을 위한 프로덕션 지원 모바일 최적화 솔루션을 제공합니다. 사용하기 쉬운 이 모바일 SDK를 사용하면 Google의 ML 전문 지식을 Android 및 iOS 앱에 직접 적용할 수 있으므로 모델 학습 및 최적화 대신 기능 개발에 집중할 수 있습니다. ML Kit는 바코드 스캔, 텍스트 인식 (OCR), 얼굴 감지, 이미지 라벨 지정, 객체 감지 및 추적, 언어 식별, 스마트 답장과 같은 기능을 위한 사전 빌드된 API와 즉시 사용 가능한 모델을 제공합니다.

이러한 모델은 일반적으로 온디바이스 실행에 최적화되어 있어 데이터가 기기에 남아 있는 경우가 많으므로 지연 시간이 짧고 오프라인 기능이 있으며 사용자 개인 정보 보호가 강화됩니다. 모델을 학습하거나 생성형 출력이 필요하지 않고도 확립된 ML 기능을 모바일 앱에 빠르게 추가하려면 ML Kit를 선택하세요. Google의 최적화된 모델을 사용하거나 맞춤 TensorFlow Lite 모델을 배포하여 '스마트' 기능으로 앱을 효율적으로 개선하는 데 적합합니다.

ML Kit 개발자 사이트에서 포괄적인 가이드와 문서를 확인하여 시작하세요.

LiteRT를 사용한 맞춤 ML 배포

더 세부적으로 제어하거나 자체 ML 모델을 배포하려면 LiteRT 및 Google Play 서비스에 기반한 맞춤 ML 스택을 사용하세요. 이 스택은 고성능 ML 기능을 배포하는 데 필요한 필수 요소를 제공합니다. LiteRT는 리소스가 제한된 모바일, 내장형, 에지 기기에서 TensorFlow 모델을 효율적으로 실행하도록 최적화된 툴킷으로, 메모리, 전력, 스토리지를 적게 사용하는 훨씬 작고 빠른 모델을 실행할 수 있습니다. LiteRT 런타임은 에지 기기의 다양한 하드웨어 가속기 (GPU, DSP, NPU)에 맞게 고도로 최적화되어 지연 시간이 짧은 추론을 지원합니다.

스마트폰, IoT 기기, 마이크로컨트롤러와 같이 컴퓨팅 성능이나 배터리 수명이 제한된 기기에 학습된 ML 모델 (일반적으로 분류, 회귀 또는 감지용)을 효율적으로 배포해야 하는 경우 LiteRT를 선택하세요. 속도와 리소스 보존이 중요한 에지에서 맞춤 예측 모델이나 표준 예측 모델을 배포하는 데 권장되는 솔루션입니다.

LiteRT를 사용한 ML 배포에 대해 자세히 알아보세요.

MediaPipe로 앱에 실시간 인식 기능 빌드

MediaPipe는 라이브 및 스트리밍 미디어를 위해 설계된 오픈소스, 크로스 플랫폼, 맞춤설정 가능한 머신러닝 솔루션을 제공합니다. 핸드 트래킹, 자세 추정, 얼굴 메쉬 감지, 객체 감지와 같은 복잡한 작업을 위해 최적화된 사전 빌드 도구를 활용하여 휴대기기에서도 고성능의 실시간 상호작용을 지원합니다.

MediaPipe의 그래프 기반 파이프라인은 맞춤설정이 가능하므로 Android, iOS, 웹, 데스크톱, 백엔드 애플리케이션에 맞게 솔루션을 조정할 수 있습니다. 애플리케이션에서 실시간 센서 데이터(특히 동영상 스트림)를 즉시 이해하고 반응해야 하는 경우, 특히 제스처 인식, AR 효과, 피트니스 추적, 아바타 제어와 같은 사용 사례에서 MediaPipe를 선택하세요. 이러한 사용 사례는 모두 입력을 분석하고 해석하는 데 중점을 둡니다.

솔루션을 살펴보고 MediaPipe로 빌드를 시작하세요.

온디바이스 또는 클라우드 방식 선택

Android 앱에 AI/ML 기능을 통합할 때 중요한 초기 결정은 사용자의 기기에서 직접 처리할지 아니면 클라우드에서 처리할지입니다. ML Kit, Gemini Nano, TensorFlow Lite와 같은 도구는 온디바이스 기능을 지원하는 반면, Firebase AI Logic이 포함된 Gemini 클라우드 API는 강력한 클라우드 기반 처리를 제공할 수 있습니다. 올바른 선택은 사용 사례와 사용자 요구사항에 따른 다양한 요인에 따라 달라집니다.

결정을 내릴 때 다음 사항을 고려하세요.

  • 연결 및 오프라인 기능: 애플리케이션이 인터넷 연결 없이 안정적으로 작동해야 하는 경우 Gemini Nano와 같은 온디바이스 솔루션이 적합합니다. 클라우드 기반 처리는 기본적으로 네트워크 액세스가 필요합니다.
  • 데이터 개인 정보 보호: 개인 정보 보호상의 이유로 사용자 데이터가 기기에 남아 있어야 하는 사용 사례의 경우 온디바이스 처리는 민감한 정보를 로컬로 유지하여 명확한 이점을 제공합니다.
  • 모델 기능 및 작업 복잡성: 클라우드 기반 모델은 크기가 훨씬 크고, 성능이 더 강력하며, 업데이트 빈도가 더 높은 경우가 많으므로 매우 복잡한 AI 작업에 적합하거나, 출력 품질과 광범위한 기능이 중요한 대규모 입력을 처리할 때 적합합니다. 간단한 작업은 온디바이스 모델로 잘 처리될 수 있습니다.
  • 비용 고려사항: Cloud API는 일반적으로 사용량 기반 가격 책정이 적용되므로 추론 수 또는 처리된 데이터 양에 따라 비용이 달라질 수 있습니다. 온디바이스 추론은 일반적으로 사용당 직접 요금이 부과되지 않지만 개발 비용이 발생하고 배터리 수명 및 전반적인 성능과 같은 기기 리소스에 영향을 미칠 수 있습니다.
  • 기기 리소스: 온디바이스 모델은 사용자 기기의 저장용량을 사용합니다. 타겟 고객이 기능을 사용할 수 있도록 Gemini Nano와 같은 특정 온디바이스 모델의 기기 호환성도 파악해야 합니다.
  • 파인 튜닝 및 맞춤설정: 특정 사용 사례에 맞게 모델을 파인 튜닝할 수 있어야 하는 경우 클라우드 기반 솔루션이 일반적으로 더 큰 유연성과 광범위한 맞춤설정 옵션을 제공합니다.
  • 크로스 플랫폼 일관성: iOS를 비롯한 여러 플랫폼에서 일관된 AI 기능이 중요한 경우, Gemini Nano와 같은 일부 온디바이스 솔루션은 아직 모든 운영체제에서 제공되지 않을 수 있습니다.

사용 사례 요구사항과 사용 가능한 옵션을 신중하게 고려하면 Android 앱을 개선하고 사용자에게 지능적이고 맞춤화된 경험을 제공할 수 있는 완벽한 AI/ML 솔루션을 찾을 수 있습니다.


AI/ML 솔루션 가이드

이 솔루션 가이드는 Android 프로젝트에 AI/ML 기술을 통합하는 데 적합한 개발자 도구를 식별하는 데 도움이 됩니다.

AI 기능의 기본 목표는 무엇인가요?

  • A) 새로운 콘텐츠 (텍스트, 이미지 설명)를 생성하거나 간단한 텍스트 처리 (텍스트 요약, 교정, 다시 쓰기)를 수행하는 경우생성형 AI로 이동
  • B) 예측, 분류, 감지, 패턴 이해 또는 실시간 스트림 (예: 동영상/오디오) 처리를 위해 기존 데이터/입력을 분석하시나요?기존 ML 및 인식으로 이동

기존 ML 및 인식

전혀 새로운 출력을 생성하는 대신 입력을 분석하고, 특징을 식별하거나, 학습된 패턴을 기반으로 예측해야 합니다.

어떤 작업을 수행하고 있나요?

  • A) 사전 빌드된 일반적인 모바일 ML 기능을 빠르게 통합해야 하나요? (예: 바코드 스캔, 텍스트 인식 (OCR), 얼굴 인식, 이미지 라벨 지정, 객체 감지 및 추적, 언어 ID, 기본 스마트 답장)
    • → 사용: ML Kit (기존 API)
    • 이유: 기존 모바일 ML 작업을 가장 쉽게 통합할 수 있으며, 온디바이스 사용 (짧은 지연 시간, 오프라인, 개인 정보 보호)에 최적화되어 있는 경우가 많습니다.
  • B) 인식 작업을 위해 실시간 스트리밍 데이터 (예: 동영상 또는 오디오)를 처리해야 하나요? (예: 핸드 트래킹, 자세 추정, 얼굴 메쉬, 동영상의 실시간 객체 감지 및 분할)
    • → 사용: MediaPipe
    • 이유: 다양한 플랫폼에서 고성능 실시간 인식 파이프라인에 특화된 프레임워크입니다.
  • C) 성능과 낮은 리소스 사용량을 우선시하면서 기기에서 자체 맞춤 학습 ML 모델 (예: 분류, 회귀, 감지)을 효율적으로 실행해야 하나요?
    • → 사용: LiteRT (TensorFlow Lite 런타임)
    • 이유: 모바일 및 에지 기기에서 맞춤 모델을 효율적으로 배포하기 위한 최적화된 런타임 (작은 크기, 빠른 추론, 하드웨어 가속).
  • D) 특정 작업에 맞게 자체 커스텀 ML 모델을 학습해야 하나요?
    • → 사용: LiteRT (TensorFlow Lite 런타임) + 맞춤 모델 학습
    • 이유: 모바일 및 에지 기기에 최적화된 맞춤 모델을 학습시키고 배포하는 도구를 제공합니다.
  • E) 미묘한 차이가 많은 다양한 언어의 고급 콘텐츠 분류, 감정 분석 또는 번역이 필요한가요?
    • 기존 ML 모델 (LiteRT 또는 클라우드를 사용하여 배포 가능)이 적합한지 또는 고급 NLU에 생성형 모델이 필요한지 고려합니다 (시작으로 돌아가 A 선택). 클라우드 기반 분류, 감정 또는 번역의 경우:
    • → 사용: 클라우드 기반 솔루션 (예: Google Cloud Natural Language API, Google Cloud Translation API, (맞춤 백엔드 또는 Vertex AI를 사용하여 액세스할 수 있음) (오프라인이거나 개인 정보 보호가 중요한 경우 기기 내 옵션보다 우선순위가 낮음)
    • 이유: 클라우드 솔루션은 강력한 모델과 광범위한 언어 지원을 제공하지만 연결이 필요하며 비용이 발생할 수 있습니다.

생성형 AI

새 콘텐츠를 만들거나, 요약하거나, 재작성하거나, 복잡한 이해 또는 상호작용 작업을 수행해야 합니다.

AI가 오프라인으로 작동해야 하나요? 데이터 개인 정보 보호를 최대한 강화(사용자 데이터를 온디바이스로 유지)해야 하나요? 아니면 클라우드 추론 비용을 피하고 싶으신가요?

  • A) 예, 오프라인, 최대 개인 정보 보호 또는 클라우드 비용 없음이 중요합니다.
  • B) 아니요, 연결이 가능하고 허용되며, 클라우드 기능과 확장성이 더 중요하거나 특정 기능에 클라우드가 필요합니다.

기기 내 생성형 AI (Gemini Nano 사용)

주의사항: 호환되는 Android 기기가 필요하며, iOS 지원이 제한적이고, 특정 토큰 한도 (프롬프트 1024개, 컨텍스트 4096개)가 있으며, 모델이 클라우드 버전보다 성능이 떨어집니다.

사용 사례가 ML Kit GenAI API에서 제공하는 간소화된 작업과 구체적으로 일치하나요? (텍스트 요약, 텍스트 교정, 텍스트 다시 쓰기, 이미지 설명 생성 또는 음성 인식 실행) 및 토큰 한도가 충분한가요?

  • A) 예:
    • → 사용: ML Kit 생성형 AI API (Gemini Nano 기반)
    • 이유: 특정 일반 생성 작업을 기기에 통합하는 가장 쉬운 방법, 기기 내 솔루션의 최우선순위
  • B) 아니요 (특정 ML Kit GenAI API를 넘어 더 유연한 프롬프트나 작업이 필요하지만 Nano의 기능 내에서 온디바이스 실행을 원하는 경우):
    • → 사용: Gemini Nano 실험용 액세스
    • 이유: 구조화된 ML Kit GenAI API를 넘어 Nano의 제한사항을 준수하는 사용 사례를 위해 기기 내에서 개방형 프롬프트 기능을 제공합니다.

클라우드 생성형 AI

더 강력한 모델을 사용하고, 연결이 필요하며, 일반적으로 추론 비용이 발생하고, 더 넓은 기기 도달범위와 더 쉬운 교차 플랫폼 (Android 및 iOS) 일관성을 제공합니다.

우선순위가 Firebase 내에서의 간편한 통합인가요, 아니면 최대한의 유연성/제어인가요?

  • A) 더 쉬운 통합, 관리형 API 환경을 선호하고 이미 Firebase를 사용하고 있나요?
  • B) 최대한 유연하고 서드 파티/맞춤 모델을 포함한 광범위한 모델에 액세스하고 고급 미세 조정이 필요하며 자체 백엔드 통합(더 복잡함)을 관리할 의향이 있나요?
    • → 사용: 맞춤 Cloud 백엔드가 있는 Gemini API (Google Cloud Platform 사용)
    • 이유: 가장 많은 제어 기능, 가장 광범위한 모델 액세스, 맞춤 학습 옵션을 제공하지만 상당한 백엔드 개발 노력이 필요합니다. 복잡하거나 대규모이거나 맞춤설정이 많이 필요한 경우에 적합합니다.

(Firebase AI Logic SDK를 선택하셨습니다.) 어떤 생성형 작업과 성능 프로필이 필요하신가요?

  • A) 속도가 중요한 일반 텍스트 생성, 요약 또는 채팅 애플리케이션에 적합한 성능과 비용의 균형이 필요하신가요?
  • B) 복잡한 텍스트 생성, 추론, 고급 NLU 또는 지침 준수를 위해 더 높은 품질과 기능이 필요한가요?
  • C) 텍스트 프롬프트를 기반으로 정교한 이미지 생성 또는 고급 이미지 이해 또는 조작이 필요한가요?