File: CountAlgo.swift

package info (click to toggle)
swiftlang 6.0.3-2
  • links: PTS, VCS
  • area: main
  • in suites: forky, sid, trixie
  • size: 2,519,992 kB
  • sloc: cpp: 9,107,863; ansic: 2,040,022; asm: 1,135,751; python: 296,500; objc: 82,456; f90: 60,502; lisp: 34,951; pascal: 19,946; sh: 18,133; perl: 7,482; ml: 4,937; javascript: 4,117; makefile: 3,840; awk: 3,535; xml: 914; fortran: 619; cs: 573; ruby: 573
file content (127 lines) | stat: -rw-r--r-- 7,214 bytes parent folder | download
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
//===--- CountAlgo.swift --------------------------------------------------===//
//
// This source file is part of the Swift.org open source project
//
// Copyright (c) 2014 - 2018 Apple Inc. and the Swift project authors
// Licensed under Apache License v2.0 with Runtime Library Exception
//
// See https://swift.org/LICENSE.txt for license information
// See https://swift.org/CONTRIBUTORS.txt for the list of Swift project authors
//
//===----------------------------------------------------------------------===//
import TestsUtils

public let benchmarks = [
  BenchmarkInfo(
    name: "CountAlgoArray",
    runFunction: run_CountAlgoArray,
    tags: [.validation, .api]),
  BenchmarkInfo(
    name: "CountAlgoString",
    runFunction: run_CountAlgoString,
    tags: [.validation, .api],
    legacyFactor: 5),
]

@inline(never)
public func run_CountAlgoArray(_ N: Int) {
  for _ in 1...10*N {
    CheckResults(numbers.count(where: { $0 & 4095 == 0 }) == 25)
  }
}

@inline(never)
public func run_CountAlgoString(_ N: Int) {
  let vowels = Set("aeiou")
  for _ in 1...N {
    CheckResults(text.count(where: vowels.contains) == 2014)
  }
}

let numbers = Array(0..<100_000)

let text = """
    Lorem ipsum dolor sit amet, consectetur adipiscing elit. Maecenas tempus
    dictum tellus placerat ultrices. Proin mauris risus, eleifend a elit ut,
    semper consectetur nibh. Nulla ultricies est a vehicula rhoncus. Morbi
    sollicitudin efficitur est a hendrerit. Interdum et malesuada fames ac ante
    ipsum primis in faucibus. Lorem ipsum dolor sit amet, consectetur
    adipiscing elit. Nulla facilisi. Sed euismod sagittis laoreet. Ut elementum
    tempus ultrices. Donec convallis mauris at faucibus maximus.
    Nullam in nunc sit amet ante tristique elementum quis ut eros. Fusce
    dignissim, ante at efficitur dapibus, ex massa convallis nibh, et venenatis
    leo leo sit amet nisl. Lorem ipsum dolor sit amet, consectetur adipiscing
    elit. Quisque sed mi eu mi rutrum accumsan vel non massa. Nunc condimentum,
    arcu eget interdum hendrerit, ipsum mi pretium felis, ut mollis erat metus
    non est. Donec eu sapien id urna lobortis eleifend et eu ipsum. Mauris
    purus dolor, consequat ac nulla a, vehicula sollicitudin nulla.
    Phasellus a congue diam. Curabitur sed orci at sem laoreet facilisis eget
    quis est. Pellentesque habitant morbi tristique senectus et netus et
    malesuada fames ac turpis egestas. Maecenas justo tellus, efficitur id
    velit at, mollis pellentesque mi. Vivamus maximus nibh et ipsum porttitor
    facilisis. Curabitur cursus lobortis erat. Sed vitae eros et dolor feugiat
    consequat. In ac massa in odio gravida dignissim. Praesent aliquam gravida
    ullamcorper.
    Etiam feugiat sit amet odio sed tincidunt. Duis dolor odio, posuere at
    pretium sed, dignissim eu diam. Aenean eu convallis orci, vitae finibus
    erat. Aliquam nec mollis tellus. Morbi luctus sed quam et vestibulum.
    Praesent id diam tempus, consectetur tortor vel, auctor orci. Aliquam
    congue ex eu sagittis sodales. Suspendisse non convallis nulla. Praesent
    elementum semper augue, et fringilla risus ullamcorper id. Fusce eu lorem
    sit amet augue fermentum tincidunt. In aliquam libero sit amet dui rhoncus,
    ac scelerisque sem porttitor. Cras venenatis, nisi quis ullamcorper
    dapibus, odio dolor rutrum magna, vel pellentesque sem lectus in tellus.
    Proin faucibus leo iaculis nulla egestas molestie.
    Phasellus vitae tortor vitae erat elementum feugiat vel vel enim. Phasellus
    fringilla lacus sed venenatis dapibus. Phasellus sagittis vel neque ut
    varius. Proin aliquam, lectus sit amet auctor finibus, lorem libero
    pellentesque turpis, ac condimentum augue felis sit amet sem. Pellentesque
    pharetra nisl nec est congue, in posuere felis maximus. In ut nulla
    sodales, pharetra neque et, venenatis dui. Mauris imperdiet, arcu vel
    hendrerit vehicula, elit massa consectetur purus, eu blandit nunc orci sit
    amet turpis. Vestibulum ultricies id lorem id maximus. Pellentesque
    feugiat, lacus et aliquet consequat, mi leo vehicula justo, dapibus dictum
    mi quam convallis magna. Quisque id pulvinar dui, consequat gravida nisl.
    Nam nec justo venenatis, tincidunt enim a, iaculis odio. Maecenas eget
    lorem posuere, euismod nisl vel, pulvinar ex. Maecenas vitae risus ipsum.
    Proin congue sem ante, sit amet sagittis odio mattis sit amet. Nullam et
    nisi nulla.
    Donec vel hendrerit metus. Praesent quis finibus erat. Aliquam erat
    volutpat. Fusce sit amet ultricies tellus, vitae dictum dolor. Morbi auctor
    dolor vel ligula pretium aliquam. Aenean lobortis vel magna vel ultricies.
    Aenean porta urna vitae ornare porta. Quisque pretium dui diam, quis
    iaculis odio venenatis non. Maecenas at lacus et ligula tincidunt feugiat
    eu vel ipsum. Proin fermentum elit et quam tempus, eget pulvinar nisl
    pharetra.
    Mauris sodales tempus erat in lobortis. Duis vitae lacinia sapien.
    Pellentesque vitae massa eget orci sodales aliquet. Orci varius natoque
    penatibus et magnis dis parturient montes, nascetur ridiculus mus. Fusce
    nisi arcu, egestas vel consectetur eu, auctor et metus. In ultricies ligula
    felis, vitae pellentesque dolor tempor ac. Praesent mi magna, ultrices ut
    ultrices vel, sollicitudin a leo.
    Nam porta, nisi in scelerisque consequat, leo lacus accumsan massa,
    venenatis faucibus tellus quam eget tellus. Curabitur pulvinar, tellus ac
    facilisis consectetur, lacus lacus venenatis est, eu pretium orci augue
    gravida nunc. Aenean odio tellus, facilisis et finibus id, varius vitae
    diam. Aenean at suscipit sem. Suspendisse porta neque at nibh semper, sit
    amet suscipit libero egestas. Donec commodo vitae justo vitae laoreet.
    Suspendisse dignissim erat id ante maximus porta. Curabitur hendrerit
    maximus odio, et maximus felis malesuada eu. Integer dapibus finibus diam,
    quis convallis metus bibendum non.
    In vel vulputate nisi, non lacinia nunc. Nullam vitae ligula finibus,
    varius arcu in, pellentesque ipsum. Morbi vel velit tincidunt quam cursus
    lacinia non in neque. Suspendisse id feugiat nibh. Vestibulum egestas eu
    leo viverra fringilla. Curabitur ultrices sollicitudin libero, non sagittis
    felis consectetur id. Aenean non metus eget leo ornare porta sed in metus.
    Nullam quis fermentum sapien, sit amet sodales mi. Maecenas nec purus urna.
    Phasellus condimentum enim nec magna convallis, eu lacinia libero
    scelerisque. Suspendisse justo libero, maximus in auctor id, euismod quis
    risus. Nam eget augue diam. Ut id risus pulvinar elit consectetur varius.
    Aliquam tincidunt tortor pretium feugiat tempor. Nunc nec feugiat ex.
    Ut pulvinar augue eget pharetra vehicula. Phasellus malesuada tempor sem,
    ut tincidunt velit convallis in. Vivamus luctus libero vitae massa tempus,
    id elementum urna iaculis. Sed eleifend quis purus quis convallis. In
    rhoncus interdum mollis. Pellentesque dictum euismod felis, eget lacinia
    elit blandit vel. Praesent elit velit, pharetra a sodales in, cursus vitae
    tortor. In vitae scelerisque tellus.
    """