Modelos Lineares Generalizados: Busca por correspondência ortogonal

Anteriormente exploramos algoritmos como LARS e Lasso para problemas de regressão esparsa. Analogamente, a Busca por Correspondência Ortogonal (OMP) é outro algoritmo eficiente para aproximação esparsa que seleciona iterativamente as features mais correlacionadas com o resíduo atual.

Conceito Fundamental do OMP

Primordialmente, o OMP é um algoritmo guloso que resolve problemas de aproximação esparsa. Decerto, ele busca encontrar uma representação esparsa dos dados usando um número limitado de features (átomos) de um dicionário.

Conforme a documentação do scikit-learn, o OMP é particularmente útil quando sabemos antecipadamente o número de features que desejamos selecionar. Similarmente ao LARS, ele constrói a solução de forma incremental, mas com uma abordagem de projeção ortogonal.

Algoritmo OMP

O algoritmo opera através dos seguintes passos iterativos:

  1. Inicializar o resíduo com o target original
  2. Encontrar a feature mais correlacionada com o resíduo atual
  3. Adicionar essa feature ao conjunto ativo
  4. Resolver o problema de mínimos quadrados usando apenas as features ativas
  5. Atualizar o resíduo subtraindo a contribuição das features selecionadas
  6. Repetir até atingir o critério de parada

Formulação Matemática

O objetivo do OMP é resolver:

\(\min_{w} ||Xw – y||_2^2\)

Sujeito a:

\(||w||_0 \leq k\)

Onde:

  • X é a matriz de features
  • y é o vetor target
  • w são os coeficientes esparsos
  • k é o número máximo de features não-zero
  • ||w||₀ é a norma L0 (número de elementos não-zero)

Implementações no Scikit-learn

Atualmente, o scikit-learn oferece duas implementações principais:

  • OrthogonalMatchingPursuit: Implementação padrão do OMP
  • OrthogonalMatchingPursuitCV: Versão com validação cruzada para seleção automática do parâmetro n_nonzero_coefs

Parâmetros Principais

Os principais parâmetros para ajuste no OMP são:

  1. n_nonzero_coefs: Número máximo de coeficientes não-zero
  2. tol: Tolerância para erro de aproximação
  3. fit_intercept: Se deve calcular intercept
  4. normalize: Se deve normalizar as features

Exemplo Prático: OMP em Ação

Ademais, vejamos um exemplo completo demonstrando o uso do Orthogonal Matching Pursuit:

Vantagens do OMP

Embora existam vários algoritmos para regressão esparsa, o OMP oferece vantagens específicas:

Vantagens Principais

  • Controle direto: Especificação explícita do número de features
  • Eficiência computacional: Algoritmo guloso com complexidade controlada
  • Garantias teóricas: Boas propriedades de recuperação sob condições específicas
  • Interpretabilidade: Ordem de seleção fornece insights sobre importância

Casos de Uso Recomendados

O Orthogonal Matching Pursuit é particularmente eficaz em:

  1. Compressed sensing: Recuperação de sinais esparsos
  2. Seleção de features com orçamento fixo: Quando há limite no número de features
  3. Problemas com dicionários grandes: Onde apenas poucos átomos são relevantes
  4. Aplicações em tempo real: Onde eficiência computacional é crucial

Considerações Práticas

Algumas recomendações importantes para uso eficaz:

  • Use OrthogonalMatchingPursuitCV quando não souber o número ideal de features
  • Normalize os dados antes de aplicar OMP para melhor performance
  • Considere a correlação entre features, pois pode afetar a ordem de seleção
  • Para problemas muito grandes, verifique a escalabilidade do algoritmo

Enfim, o Orthogonal Matching Pursuit representa uma abordagem elegante e eficiente para problemas de aproximação esparsa, oferecendo controle direto sobre a esparsidade da solução e boas propriedades teóricas de recuperação.

Referência: https://scikit-learn.org/0.21/modules/linear_model.html#orthogonal-matching-pursuit-omp