OLD | NEW |
---|---|
1 // Copyright (c) 2012 The Chromium Authors. All rights reserved. | 1 // Copyright (c) 2012 The Chromium Authors. All rights reserved. |
2 // Use of this source code is governed by a BSD-style license that can be | 2 // Use of this source code is governed by a BSD-style license that can be |
3 // found in the LICENSE file. | 3 // found in the LICENSE file. |
4 | 4 |
5 #include "chrome/browser/prerender/prerender_field_trial.h" | 5 #include "chrome/browser/prerender/prerender_field_trial.h" |
6 | 6 |
7 #include "base/command_line.h" | 7 #include "base/command_line.h" |
8 #include "base/logging.h" | 8 #include "base/logging.h" |
9 #include "base/metrics/field_trial.h" | 9 #include "base/metrics/field_trial.h" |
10 #include "base/metrics/histogram.h" | 10 #include "base/metrics/histogram.h" |
(...skipping 30 matching lines...) Expand all Loading... | |
41 "Prefetch", divisor, "ContentPrefetchPrefetchOff", | 41 "Prefetch", divisor, "ContentPrefetchPrefetchOff", |
42 2013, 6, 30, NULL)); | 42 2013, 6, 30, NULL)); |
43 const int kPrefetchOnGroup = trial->AppendGroup("ContentPrefetchPrefetchOn", | 43 const int kPrefetchOnGroup = trial->AppendGroup("ContentPrefetchPrefetchOn", |
44 prefetch_probability); | 44 prefetch_probability); |
45 PrerenderManager::SetIsPrefetchEnabled(trial->group() == kPrefetchOnGroup); | 45 PrerenderManager::SetIsPrefetchEnabled(trial->group() == kPrefetchOnGroup); |
46 } | 46 } |
47 | 47 |
48 void SetupPrerenderFieldTrial() { | 48 void SetupPrerenderFieldTrial() { |
49 base::FieldTrial::Probability divisor = 1000; | 49 base::FieldTrial::Probability divisor = 1000; |
50 | 50 |
51 base::FieldTrial::Probability exp1_probability = 166; | 51 base::FieldTrial::Probability exp1_probability = 150; |
dominich
2012/07/19 16:04:38
I would very much like to remove half of these now
gavinp
2012/07/23 18:35:21
I like that plan, but I figured a separate CL for
| |
52 base::FieldTrial::Probability exp1_5min_ttl_probability = 83; | 52 base::FieldTrial::Probability exp1_5min_ttl_probability = 67; |
53 base::FieldTrial::Probability control1_probability = 166; | 53 base::FieldTrial::Probability control1_probability = 150; |
54 base::FieldTrial::Probability no_use1_probability = 83; | 54 base::FieldTrial::Probability no_use1_probability = 67; |
55 base::FieldTrial::Probability one_prerender1_probability = 66; | |
dominich
2012/07/19 16:04:38
We should flip this around. have exp[12] be single
gavinp
2012/07/23 18:35:21
Done.
| |
55 | 56 |
56 base::FieldTrial::Probability exp2_probability = 167; | 57 base::FieldTrial::Probability exp2_probability = 150; |
57 base::FieldTrial::Probability exp2_5min_ttl_probability = 84; | 58 base::FieldTrial::Probability exp2_5min_ttl_probability = 67; |
58 base::FieldTrial::Probability control2_probability = 167; | 59 base::FieldTrial::Probability control2_probability = 150; |
59 base::FieldTrial::Probability no_use2_probability = 84; | 60 base::FieldTrial::Probability no_use2_probability = 67; |
61 base::FieldTrial::Probability one_prerender2_probability = 66; | |
60 | 62 |
61 chrome::VersionInfo::Channel channel = chrome::VersionInfo::GetChannel(); | 63 chrome::VersionInfo::Channel channel = chrome::VersionInfo::GetChannel(); |
62 if (channel == chrome::VersionInfo::CHANNEL_STABLE || | 64 if (channel == chrome::VersionInfo::CHANNEL_STABLE || |
63 channel == chrome::VersionInfo::CHANNEL_BETA) { | 65 channel == chrome::VersionInfo::CHANNEL_BETA) { |
64 exp1_probability = 490; | 66 exp1_probability = 0; |
65 exp1_5min_ttl_probability = 5; | 67 exp1_5min_ttl_probability = 5; |
66 control1_probability = 5; | 68 control1_probability = 5; |
67 no_use1_probability = 0; | 69 no_use1_probability = 0; |
68 exp2_probability = 490; | 70 one_prerender1_probability = 490; |
71 exp2_probability = 0; | |
69 exp2_5min_ttl_probability = 5; | 72 exp2_5min_ttl_probability = 5; |
70 control2_probability = 5; | 73 control2_probability = 5; |
71 no_use2_probability = 0; | 74 no_use2_probability = 0; |
75 one_prerender2_probability = 490; | |
72 } | 76 } |
73 CHECK_EQ(divisor, exp1_probability + exp1_5min_ttl_probability + | 77 CHECK_EQ(divisor, exp1_probability + exp1_5min_ttl_probability + |
74 control1_probability + no_use1_probability + exp2_probability + | 78 control1_probability + no_use1_probability + |
79 one_prerender1_probability + exp2_probability + | |
75 exp2_5min_ttl_probability + control2_probability + | 80 exp2_5min_ttl_probability + control2_probability + |
76 no_use2_probability); | 81 no_use2_probability + one_prerender2_probability); |
77 int experiment_1_group = -1; | 82 int experiment_1_group = -1; |
78 scoped_refptr<base::FieldTrial> trial( | 83 scoped_refptr<base::FieldTrial> trial( |
79 base::FieldTrialList::FactoryGetFieldTrial( | 84 base::FieldTrialList::FactoryGetFieldTrial( |
80 "Prerender", divisor, "ContentPrefetchPrerender1", | 85 "Prerender", divisor, "ContentPrefetchPrerender1", |
81 2013, 6, 30, &experiment_1_group)); | 86 2013, 6, 30, &experiment_1_group)); |
82 | 87 |
83 const int experiment_15_min_TTL_group = | 88 const int experiment_15_min_TTL_group = |
84 trial->AppendGroup("ContentPrefetchPrerenderExp5minTTL1", | 89 trial->AppendGroup("ContentPrefetchPrerenderExp5minTTL1", |
85 exp1_5min_ttl_probability); | 90 exp1_5min_ttl_probability); |
86 const int control_1_group = | 91 const int control_1_group = |
87 trial->AppendGroup("ContentPrefetchPrerenderControl1", | 92 trial->AppendGroup("ContentPrefetchPrerenderControl1", |
88 control1_probability); | 93 control1_probability); |
89 const int no_use_1_group = | 94 const int no_use_1_group = |
90 trial->AppendGroup("ContentPrefetchPrerenderNoUse1", | 95 trial->AppendGroup("ContentPrefetchPrerenderNoUse1", |
91 no_use1_probability); | 96 no_use1_probability); |
97 const int one_prerender_1_group = | |
98 trial->AppendGroup("ContentPrefetchPrerenderOne", | |
99 one_prerender1_probability); | |
92 const int experiment_2_group = | 100 const int experiment_2_group = |
93 trial->AppendGroup("ContentPrefetchPrerender2", | 101 trial->AppendGroup("ContentPrefetchPrerender2", |
94 exp2_probability); | 102 exp2_probability); |
95 const int experiment_25_min_TTL_group = | 103 const int experiment_25_min_TTL_group = |
96 trial->AppendGroup("ContentPrefetchPrerenderExp5minTTL2", | 104 trial->AppendGroup("ContentPrefetchPrerenderExp5minTTL2", |
97 exp2_5min_ttl_probability); | 105 exp2_5min_ttl_probability); |
98 const int control_2_group = | 106 const int control_2_group = |
99 trial->AppendGroup("ContentPrefetchPrerenderControl2", | 107 trial->AppendGroup("ContentPrefetchPrerenderControl2", |
100 control2_probability); | 108 control2_probability); |
101 const int no_use_2_group = | 109 const int no_use_2_group = |
102 trial->AppendGroup("ContentPrefetchPrerenderNoUse2", | 110 trial->AppendGroup("ContentPrefetchPrerenderNoUse2", |
103 no_use2_probability); | 111 no_use2_probability); |
112 const int one_prerender_2_group = | |
113 trial->AppendGroup("ContentPrefetchPrerenderOne", | |
114 one_prerender2_probability); | |
104 const int trial_group = trial->group(); | 115 const int trial_group = trial->group(); |
105 if (trial_group == experiment_1_group || | 116 if (trial_group == experiment_1_group || |
106 trial_group == experiment_2_group) { | 117 trial_group == experiment_2_group) { |
107 PrerenderManager::SetMode( | 118 PrerenderManager::SetMode( |
108 PrerenderManager::PRERENDER_MODE_EXPERIMENT_PRERENDER_GROUP); | 119 PrerenderManager::PRERENDER_MODE_EXPERIMENT_PRERENDER_GROUP); |
109 } else if (trial_group == experiment_15_min_TTL_group || | 120 } else if (trial_group == experiment_15_min_TTL_group || |
110 trial_group == experiment_25_min_TTL_group) { | 121 trial_group == experiment_25_min_TTL_group) { |
111 PrerenderManager::SetMode( | 122 PrerenderManager::SetMode( |
112 PrerenderManager::PRERENDER_MODE_EXPERIMENT_5MIN_TTL_GROUP); | 123 PrerenderManager::PRERENDER_MODE_EXPERIMENT_5MIN_TTL_GROUP); |
113 } else if (trial_group == control_1_group || | 124 } else if (trial_group == control_1_group || |
114 trial_group == control_2_group) { | 125 trial_group == control_2_group) { |
115 PrerenderManager::SetMode( | 126 PrerenderManager::SetMode( |
116 PrerenderManager::PRERENDER_MODE_EXPERIMENT_CONTROL_GROUP); | 127 PrerenderManager::PRERENDER_MODE_EXPERIMENT_CONTROL_GROUP); |
117 } else if (trial_group == no_use_1_group || | 128 } else if (trial_group == no_use_1_group || |
118 trial_group == no_use_2_group) { | 129 trial_group == no_use_2_group) { |
119 PrerenderManager::SetMode( | 130 PrerenderManager::SetMode( |
120 PrerenderManager::PRERENDER_MODE_EXPERIMENT_NO_USE_GROUP); | 131 PrerenderManager::PRERENDER_MODE_EXPERIMENT_NO_USE_GROUP); |
132 } else if (trial_group == one_prerender_1_group || | |
133 trial_group == one_prerender_2_group) { | |
134 PrerenderManager::SetMode( | |
135 PrerenderManager::PRERENDER_MODE_EXPERIMENT_ONE_PRERENDER_GROUP); | |
121 } else { | 136 } else { |
122 NOTREACHED(); | 137 NOTREACHED(); |
123 } | 138 } |
124 } | 139 } |
125 | 140 |
126 } // end namespace | 141 } // end namespace |
127 | 142 |
128 void ConfigureOmniboxPrerender(); | 143 void ConfigureOmniboxPrerender(); |
129 void ConfigureSpeculativePrefetching(); | 144 void ConfigureSpeculativePrefetching(); |
130 | 145 |
(...skipping 141 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
272 if (switch_value == switches::kSpeculativeResourcePrefetchingLearning) | 287 if (switch_value == switches::kSpeculativeResourcePrefetchingLearning) |
273 return true; | 288 return true; |
274 } | 289 } |
275 | 290 |
276 const int group = base::FieldTrialList::FindValue( | 291 const int group = base::FieldTrialList::FindValue( |
277 kSpeculativePrefetchingLearningTrialName); | 292 kSpeculativePrefetchingLearningTrialName); |
278 return group == g_speculative_prefetching_learning_default_group_number; | 293 return group == g_speculative_prefetching_learning_default_group_number; |
279 } | 294 } |
280 | 295 |
281 } // namespace prerender | 296 } // namespace prerender |
OLD | NEW |