| // Copyright 2020 The Chromium Authors. All rights reserved. |
| // Use of this source code is governed by a BSD-style license that can be |
| // found in the LICENSE file. |
| |
| #include "components/omnibox/browser/voice_suggest_provider.h" |
| |
| #include <string> |
| |
| #include "components/omnibox/browser/autocomplete_input.h" |
| #include "components/omnibox/browser/autocomplete_match.h" |
| #include "components/omnibox/browser/autocomplete_match_classification.h" |
| #include "components/search_engines/template_url.h" |
| #include "components/search_engines/template_url_service.h" |
| |
| namespace { |
| // Maximum and minimum score allowed for voice suggestions. |
| // The score is multiplied by confidence score to produce suggestion relevance. |
| constexpr const int kMaxVoiceSuggestionScore = 1250; |
| constexpr const int kMinVoiceSuggestionScore = 350; |
| constexpr const float kConfidenceAlternativesCutoff = 0.8f; |
| constexpr const float kConfidenceRelevanceCutoff = 0.3f; |
| constexpr const int kMaxVoiceMatchesToOffer = 3; |
| |
| // Calculate relevance score for voice suggestion from confidence score. |
| constexpr int ConfidenceScoreToSuggestionScore(float confidence_score) { |
| return (kMaxVoiceSuggestionScore - kMinVoiceSuggestionScore) * |
| confidence_score + |
| kMinVoiceSuggestionScore; |
| } |
| } // namespace |
| |
| VoiceSuggestProvider::VoiceSuggestProvider( |
| AutocompleteProviderClient* client, |
| AutocompleteProviderListener* listener) |
| : BaseSearchProvider(TYPE_VOICE_SUGGEST, client) {} |
| |
| VoiceSuggestProvider::~VoiceSuggestProvider() = default; |
| |
| void VoiceSuggestProvider::Start(const AutocompleteInput& input, |
| bool minimal_changes) { |
| autocomplete_input_ = &input; |
| |
| MatchMap map; |
| int index = 0; |
| for (const auto& score_and_suggestion_pair : voice_matches_) { |
| // Drop suggestions that do not meet the bar. |
| if (score_and_suggestion_pair.first < kConfidenceRelevanceCutoff) |
| break; |
| |
| AddMatchToMap( |
| SearchSuggestionParser::SuggestResult( |
| score_and_suggestion_pair.second, |
| AutocompleteMatchType::VOICE_SUGGEST, {}, false, |
| ConfidenceScoreToSuggestionScore(score_and_suggestion_pair.first), |
| false, {}), |
| {}, index, false, false, &map); |
| ++index; |
| |
| // Stop if the first voice suggestion has a high relevance score suggesting |
| // it is properly identified, or if we supplied enough voice matches. |
| if ((score_and_suggestion_pair.first >= kConfidenceAlternativesCutoff) || |
| (index >= kMaxVoiceMatchesToOffer)) |
| break; |
| } |
| |
| for (auto& match_pair : map) { |
| matches_.push_back(std::move(match_pair.second)); |
| } |
| |
| autocomplete_input_ = nullptr; |
| } |
| |
| const TemplateURL* VoiceSuggestProvider::GetTemplateURL(bool is_keyword) const { |
| DCHECK(!is_keyword); |
| return client()->GetTemplateURLService()->GetDefaultSearchProvider(); |
| } |
| |
| const AutocompleteInput VoiceSuggestProvider::GetInput(bool is_keyword) const { |
| DCHECK(!is_keyword); |
| DCHECK(autocomplete_input_); |
| return *autocomplete_input_; |
| } |
| |
| bool VoiceSuggestProvider::ShouldAppendExtraParams( |
| const SearchSuggestionParser::SuggestResult& result) const { |
| // We always use the default provider for search, so append the params. |
| return true; |
| } |
| |
| void VoiceSuggestProvider::RecordDeletionResult(bool success) {} |
| |
| void VoiceSuggestProvider::Stop(bool clear_cached_results, |
| bool due_to_user_inactivity) { |
| if (clear_cached_results) { |
| ClearCache(); |
| } |
| matches_.clear(); |
| } |
| |
| void VoiceSuggestProvider::ClearCache() { |
| voice_matches_.clear(); |
| } |
| |
| void VoiceSuggestProvider::AddVoiceSuggestion(std::u16string voice_match, |
| float confidence_score) { |
| voice_matches_.emplace_back(confidence_score, std::move(voice_match)); |
| } |