public new static vtkDiagonalMatrixSource New()
        {
            vtkDiagonalMatrixSource result = null;
            uint   mteStatus   = 0u;
            uint   mteIndex    = 4294967295u;
            uint   rawRefCount = 0u;
            IntPtr intPtr      = vtkDiagonalMatrixSource.vtkDiagonalMatrixSource_New(ref mteStatus, ref mteIndex, ref rawRefCount);

            if (IntPtr.Zero != intPtr)
            {
                bool flag;
                result = (vtkDiagonalMatrixSource)Methods.CreateWrappedObject(mteStatus, mteIndex, rawRefCount, intPtr, true, out flag);
            }
            return(result);
        }
        public new static vtkDiagonalMatrixSource SafeDownCast(vtkObjectBase o)
        {
            vtkDiagonalMatrixSource vtkDiagonalMatrixSource = null;
            uint   mteStatus   = 0u;
            uint   mteIndex    = 4294967295u;
            uint   rawRefCount = 0u;
            IntPtr intPtr      = vtkDiagonalMatrixSource.vtkDiagonalMatrixSource_SafeDownCast_12((o == null) ? default(HandleRef) : o.GetCppThis(), ref mteStatus, ref mteIndex, ref rawRefCount);

            if (IntPtr.Zero != intPtr)
            {
                bool flag;
                vtkDiagonalMatrixSource = (vtkDiagonalMatrixSource)Methods.CreateWrappedObject(mteStatus, mteIndex, rawRefCount, intPtr, true, out flag);
                if (flag)
                {
                    vtkDiagonalMatrixSource.Register(null);
                }
            }
            return(vtkDiagonalMatrixSource);
        }