summaryrefslogtreecommitdiff
path: root/examples/bench.py
blob: b8d8c3658074bbbdafe3a9a14f27cb5460c29165 (plain)
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
#!/usr/bin/env python3

import time
from pathlib import Path

import tqdm

import gerbonara

if __name__ == '__main__':
    resources = Path(__file__).parent.parent / 'gerbonara' / 'tests' / 'resources'

    TEST_FILES = [
        'easyeda/Gerber_TopSilkLayer.GTO',
        'allegro-2/MinnowMax_RevA1_GAF_Gerber/MinnowMax_lyr3.art',
        'allegro-2/MinnowMax_RevA1_GAF_Gerber/MinnowMax_fab.art',
        'eagle-newer/soldermask_bottom.gbr',
        'eagle-newer/copper_bottom.gbr',
# FIXME remove redundant warnings in these files
#        'siemens/80101_0125_F200_SilkscreenBottom.gdo',
#        'siemens/80101_0125_F200_SoldermaskBottom.gdo',
#        'siemens/80101_0125_F200_SolderPasteBottom.gdo',
#        'siemens/80101_0125_F200_L03.gdo',
#        'siemens/80101_0125_F200_L01_Top.gdo',
#        'zuken-emulated/Gerber/Symbol-A.fph',
        'Target3001/IRNASIoTbank1.2.StopTop',
        'Target3001/IRNASIoTbank1.2.PasteTop',
        'Target3001/IRNASIoTbank1.2.PasteBot',
        'Target3001/IRNASIoTbank1.2.StopBot',
        'Target3001/IRNASIoTbank1.2.Top',
        'pcb-rnd/power-art.gtl',
        'pcb-rnd/power-art.gto',
        'pcb-rnd/power-art.gtp',
        'altium-composite-drill/Gerber/LimeSDR-QPCIe_1v2.G1',
        'altium-composite-drill/Gerber/LimeSDR-QPCIe_1v2.G2',
        'altium-composite-drill/Gerber/LimeSDR-QPCIe_1v2.G3',
        'altium-composite-drill/Gerber/LimeSDR-QPCIe_1v2.G4',
        'altium-composite-drill/Gerber/LimeSDR-QPCIe_1v2.G5',
        'altium-composite-drill/Gerber/LimeSDR-QPCIe_1v2.G6',
        'altium-composite-drill/Gerber/LimeSDR-QPCIe_1v2.G7',
        'altium-composite-drill/Gerber/LimeSDR-QPCIe_1v2.G8',
        'altium-composite-drill/Gerber/LimeSDR-QPCIe_1v2.G9',
        'altium-composite-drill/Gerber/LimeSDR-QPCIe_1v2.G10',
        'altium-composite-drill/Gerber/LimeSDR-QPCIe_1v2.G11',
        'altium-composite-drill/Gerber/LimeSDR-QPCIe_1v2.G12',
        'altium-composite-drill/Gerber/LimeSDR-QPCIe_1v2.GBS',
        'eagle_files/copper_top_l1.gbr',
        'eagle_files/soldermask_top.gbr',
        'diptrace/mainboard_Bottom.gbr',
        'upverter/design_export.gtp',
        'upverter/design_export.gbl',
        ]

    start = time.perf_counter()
    for file in TEST_FILES: #tqdm.tqdm(TEST_FILES):
        gerbonara.GerberFile.open(resources / file)
    end = time.perf_counter()

    print(f'Duration: {(end - start)*1000:.3f} ms')