/usr/include/openturns/swig/Copula.i is in libopenturns-dev 1.9-5.
This file is owned by root:root, with mode 0o644.
The actual contents of the file can be viewed below.
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 | // SWIG file Copula.i
%{
#include "openturns/PythonWrappingFunctions.hxx"
#include "openturns/Copula.hxx"
namespace OT {
template <>
struct traitsPythonType<OT::Copula>
{
typedef _PyObject_ Type;
};
template <>
inline
OT::Copula
convert<_PyObject_,OT::Copula>(PyObject * pyObj)
{
void * ptr = 0;
if (SWIG_IsOK(SWIG_ConvertPtr( pyObj, &ptr, SWIGTYPE_p_OT__Copula, 0 | 0 ))) {
OT::Copula * p_copula = reinterpret_cast< OT::Copula * >( ptr );
return *p_copula;
} else if (SWIG_IsOK(SWIG_ConvertPtr( pyObj, &ptr, SWIGTYPE_p_OT__CopulaImplementation, 0 | 0 ))) {
OT::CopulaImplementation * p_copula = reinterpret_cast< OT::CopulaImplementation * >( ptr );
return *p_copula;
} else if (SWIG_IsOK(SWIG_ConvertPtr( pyObj, &ptr, SWIGTYPE_p_OT__Distribution, 0 | 0 ))) {
OT::Distribution * p_dist = reinterpret_cast< OT::Distribution * >( ptr );
return *p_dist;
} else if (SWIG_IsOK(SWIG_ConvertPtr( pyObj, &ptr, SWIGTYPE_p_OT__DistributionImplementation, 0 | 0 ))) {
OT::DistributionImplementation * p_dist = reinterpret_cast< OT::DistributionImplementation * >( ptr );
return *p_dist;
} else if (isAPython<_PySequence_>( pyObj )) {
check<_PySequence_>( pyObj );
ScopedPyObjectPointer newPyObj(PySequence_Fast( pyObj, "" ));
const UnsignedInteger size = PySequence_Fast_GET_SIZE( newPyObj.get() );
if (size != 2) {
throw OT::InvalidArgumentException(HERE) << "Sequence object has incorrect size " << size << ". Must be 2.";
}
PyObject * elt1 = PySequence_Fast_GET_ITEM( newPyObj.get(), 0 );
check<_PyObject_>( elt1 );
PyObject * elt2 = PySequence_Fast_GET_ITEM( newPyObj.get(), 1 );
check<_PyString_>( elt2 );
OT::Copula copula = convert<_PyObject_,OT::Copula>( elt1 );
copula.setName( convert<_PyString_,OT::String>( elt2 ) );
return copula;
} else {
throw OT::InvalidArgumentException(HERE) << "Object passed as argument is neither a Copula nor an object convertible to a Copula";
}
return OT::Copula();
}
} /* namespace OT */
%}
%include Copula_doc.i
%typemap(in) const OT::Copula & {
void * ptr = 0;
if (SWIG_IsOK(SWIG_ConvertPtr($input, (void **) &$1, $1_descriptor, 0))) {
// From interface class, ok
} else if (SWIG_IsOK(SWIG_ConvertPtr($input, &ptr, SWIGTYPE_p_OT__CopulaImplementation, 0))) {
// From Implementation*
OT::CopulaImplementation * p_impl = reinterpret_cast< OT::CopulaImplementation * >( ptr );
$1 = new OT::Copula( *p_impl );
} else if (SWIG_IsOK(SWIG_ConvertPtr($input, &ptr, SWIGTYPE_p_OT__Distribution, 0))) {
// From Distribution*
OT::Distribution * p_dist = reinterpret_cast< OT::Distribution * >( ptr );
$1 = new OT::Copula( p_dist->getImplementation() );
} else if (SWIG_IsOK(SWIG_ConvertPtr($input, &ptr, SWIG_TypeQuery("OT::Pointer<OT::DistributionImplementation> *"), 0))) {
// From Pointer<DistributionImplementation>
OT::Pointer<OT::DistributionImplementation> * p_impl = reinterpret_cast< OT::Pointer<OT::DistributionImplementation> * >( ptr );
$1 = new OT::Copula( **p_impl );
} else if (SWIG_IsOK(SWIG_ConvertPtr($input, &ptr, SWIGTYPE_p_OT__DistributionImplementation, 0))) {
// From DistributionImplementation
OT::DistributionImplementation * p_impl = reinterpret_cast< OT::DistributionImplementation * >( ptr );
$1 = new OT::Copula( *p_impl );
} else {
SWIG_exception(SWIG_TypeError, "Object passed as argument is not convertible to a Copula");
}
}
%typemap(typecheck,precedence=SWIG_TYPECHECK_POINTER) const OT::Copula & {
$1 = SWIG_IsOK(SWIG_ConvertPtr($input, NULL, $1_descriptor, 0))
|| SWIG_IsOK(SWIG_ConvertPtr($input, NULL, SWIGTYPE_p_OT__CopulaImplementation, 0))
|| SWIG_IsOK(SWIG_ConvertPtr($input, NULL, SWIGTYPE_p_OT__Distribution, 0))
|| SWIG_IsOK(SWIG_ConvertPtr($input, NULL, SWIG_TypeQuery("OT::Pointer<OT::DistributionImplementation> *"), 0))
|| SWIG_IsOK(SWIG_ConvertPtr($input, NULL, SWIGTYPE_p_OT__DistributionImplementation, 0));
}
%include openturns/Copula.hxx
namespace OT { %extend Copula { Copula(const Copula & other) { return new OT::Copula(other); } } }
|