vunit issue_vunit (issue(psl)) {
-- VHDL declaration seem to be working
signal a_delayed : std_logic := '0';
-- Other VHDL code not
-- results in parser errors
-- during synthesis
process is
begin
wait until rising_edge(clk);
a_delayed <= a;
end process;
-- All is sensitive to rising edge of clk
default clock is rising_edge(clk);
-- This assertion holds
CHECK_a : assert always (a -> b);
-- You can't do anything with the declared signal
-- Can be synthesized with GHDL, however
-- results in error in ghdl-yosys-plugin:
-- ERROR: Assert `n.id != 0' failed in src/ghdl.cc:172
assert always a_delayed = prev(a);
}
rc='/cgit.png' alt='cgit logo'/>
blob: 3ce9ea0286e9dbd5fc795e60ae77a3c9afa356b8 (
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
|
.. _type-conversions:
Type conversions
################
Apart from enabling cross-language function calls, a fundamental problem
that a binding tool like pybind11 must address is to provide access to
native Python types in C++ and vice versa. There are three fundamentally
different ways to do this—which approach is preferable for a particular type
depends on the situation at hand.
1. Use a native C++ type everywhere. In this case, the type must be wrapped
using pybind11-generated bindings so that Python can interact with it.
2. Use a native Python type everywhere. It will need to be wrapped so that
C++ functions can interact with it.
3. Use a native C++ type on the C++ side and a native Python type on the
Python side. pybind11 refers to this as a *type conversion*.
Type conversions are the most "natural" option in the sense that native
(non-wrapped) types are used everywhere. The main downside is that a copy
of the data must be made on every Python ↔ C++ transition: this is
needed since the C++ and Python versions of the same type generally won't
have the same memory layout.
pybind11 can perform many kinds of conversions automatically. An overview
is provided in the table ":ref:`conversion_table`".
The following subsections discuss the differences between these options in more
detail. The main focus in this section is on type conversions, which represent
the last case of the above list.
.. toctree::
:maxdepth: 1
overview
strings
stl
functional
chrono
eigen
custom
|