1484543d1Sopenharmony_ci/*
2484543d1Sopenharmony_ci * Copyright (c) 2023 Huawei Device Co., Ltd.
3484543d1Sopenharmony_ci * Licensed under the Apache License, Version 2.0 (the "License");
4484543d1Sopenharmony_ci * you may not use this file except in compliance with the License.
5484543d1Sopenharmony_ci * You may obtain a copy of the License at
6484543d1Sopenharmony_ci *
7484543d1Sopenharmony_ci *     http://www.apache.org/licenses/LICENSE-2.0
8484543d1Sopenharmony_ci *
9484543d1Sopenharmony_ci * Unless required by applicable law or agreed to in writing, software
10484543d1Sopenharmony_ci * distributed under the License is distributed on an "AS IS" BASIS,
11484543d1Sopenharmony_ci * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
12484543d1Sopenharmony_ci * See the License for the specific language governing permissions and
13484543d1Sopenharmony_ci * limitations under the License.
14484543d1Sopenharmony_ci */
15484543d1Sopenharmony_ci
16484543d1Sopenharmony_ci#include "ffrt_inner.h"
17484543d1Sopenharmony_ci#include "common.h"
18484543d1Sopenharmony_ci
19484543d1Sopenharmony_ciint main()
20484543d1Sopenharmony_ci{
21484543d1Sopenharmony_ci    int64_t ffrt_time = 0;
22484543d1Sopenharmony_ci    uint32_t count = 10000;
23484543d1Sopenharmony_ci    uint32_t max_min = 2000; // us
24484543d1Sopenharmony_ci    uint32_t min = 0;
25484543d1Sopenharmony_ci    uint32_t max = max_min;
26484543d1Sopenharmony_ci    completely_paralle(count, max_min, ffrt_time); // pre hot ffrt
27484543d1Sopenharmony_ci    while ((max - min) > 1) {
28484543d1Sopenharmony_ci        // use binay search to get the min granularity of tasks that can obtain benefits
29484543d1Sopenharmony_ci        uint32_t median = (max + min) / 2;
30484543d1Sopenharmony_ci        completely_paralle(count, median, ffrt_time);
31484543d1Sopenharmony_ci        float speedup = (1.0f * count * median) / ffrt_time;
32484543d1Sopenharmony_ci        printf("duration:%u speedup:%.2f\n", median, speedup);
33484543d1Sopenharmony_ci        if (speedup > 1) {
34484543d1Sopenharmony_ci            max = median;
35484543d1Sopenharmony_ci        } else {
36484543d1Sopenharmony_ci            min = median;
37484543d1Sopenharmony_ci        }
38484543d1Sopenharmony_ci    }
39484543d1Sopenharmony_ci    return 0;
40484543d1Sopenharmony_ci}
41484543d1Sopenharmony_ci
42