using System.Runtime.InteropServices;
using OpenCvSharp.Internal.Util;
using OpenCvSharp.ML;
namespace OpenCvSharp.Internal.Vectors;
///
///
internal class VectorOfDTreesSplit : DisposableCvObject, IStdVector
{
///
/// Constructor
///
public VectorOfDTreesSplit()
{
ptr = NativeMethods.vector_DTrees_Split_new1();
}
///
/// Releases unmanaged resources
///
protected override void DisposeUnmanaged()
{
NativeMethods.vector_DTrees_Split_delete(ptr);
base.DisposeUnmanaged();
}
///
/// vector.size()
///
public int Size
{
get
{
var res = NativeMethods.vector_DTrees_Split_getSize(ptr);
GC.KeepAlive(this);
return (int)res;
}
}
///
/// &vector[0]
///
public IntPtr ElemPtr
{
get
{
var res = NativeMethods.vector_DTrees_Split_getPointer(ptr);
GC.KeepAlive(this);
return res;
}
}
///
/// Converts std::vector to managed array
///
///
public DTrees.Split[] ToArray()
{
var size = Size;
if (size == 0)
{
return Array.Empty();
}
var dst = new DTrees.Split[size];
using (var dstPtr = new ArrayAddress1(dst))
{
long bytesToCopy = Marshal.SizeOf() * dst.Length;
unsafe
{
Buffer.MemoryCopy(ElemPtr.ToPointer(), dstPtr.Pointer.ToPointer(), bytesToCopy, bytesToCopy);
}
}
GC.KeepAlive(this); // ElemPtr is IntPtr to memory held by this object, so
// make sure we are not disposed until finished with copy.
return dst;
}
}