forked from OpenTimer/OpenTimer
-
Notifications
You must be signed in to change notification settings - Fork 1
Expand file tree
/
Copy pathtest_simple_timing.cpp
More file actions
36 lines (28 loc) · 1.28 KB
/
test_simple_timing.cpp
File metadata and controls
36 lines (28 loc) · 1.28 KB
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
#include <iostream>
#include <ot/liberty/celllib.hpp>
int main() {
std::cout << "Testing simple timing parsing..." << std::endl;
try {
ot::Celllib lib;
lib.read("test_ccs_minimal.lib");
std::cout << "Library loaded successfully!" << std::endl;
std::cout << "Number of cells: " << lib.cells.size() << std::endl;
for (const auto& [cell_name, cell] : lib.cells) {
std::cout << "Cell: " << cell_name << std::endl;
for (const auto& [pin_name, pin] : cell.cellpins) {
std::cout << " Pin: " << pin_name << " has " << pin.timings.size() << " timing arcs" << std::endl;
for (size_t i = 0; i < pin.timings.size(); i++) {
const auto& timing = pin.timings[i];
std::cout << " Timing " << i << ": " << std::endl;
std::cout << " output_current_fall size: " << timing.output_current_fall.size() << std::endl;
std::cout << " output_current_rise size: " << timing.output_current_rise.size() << std::endl;
}
}
break; // Just test first cell
}
} catch (const std::exception& e) {
std::cerr << "Error: " << e.what() << std::endl;
return 1;
}
return 0;
}