Delete vl-modinsts by instname.
(vl-delete-modinsts-by-instname names x) → filtered-x
Function:
(defun vl-delete-modinsts-by-instname (names x) (declare (xargs :guard (and (string-listp names) (vl-modinstlist-p x)))) (let ((__function__ 'vl-delete-modinsts-by-instname)) (declare (ignorable __function__)) (mbe :logic (cond ((atom x) nil) ((member-equal (vl-modinst->instname (car x)) (string-list-fix names)) (vl-delete-modinsts-by-instname names (cdr x))) (t (cons (vl-modinst-fix (car x)) (vl-delete-modinsts-by-instname names (cdr x))))) :exec (b* (((when (atom names)) (list-fix x)) ((when (atom x)) nil) ((unless (longer-than-p 10 names)) (vl-slow-delete-modinsts-by-instname names x)) (fal (make-lookup-alist names)) (ans (with-local-nrev (vl-fast-delete-modinsts-by-instname names fal x nrev))) (- (fast-alist-free fal))) ans))))
Theorem:
(defthm vl-modinstlist-p-of-vl-delete-modinsts-by-instname (b* ((filtered-x (vl-delete-modinsts-by-instname names x))) (vl-modinstlist-p filtered-x)) :rule-classes :rewrite)
Theorem:
(defthm vl-delete-modinsts-by-instname-when-atom (implies (atom x) (equal (vl-delete-modinsts-by-instname names x) nil)))
Theorem:
(defthm vl-delete-modinsts-by-instname-of-cons (equal (vl-delete-modinsts-by-instname names (cons a x)) (if (member-equal (vl-modinst->instname a) (string-list-fix names)) (vl-delete-modinsts-by-instname names x) (cons (vl-modinst-fix a) (vl-delete-modinsts-by-instname names x)))))
Theorem:
(defthm member-equal-of-vl-delete-modinsts-by-instname (iff (member-equal a (vl-delete-modinsts-by-instname names x)) (and (member-equal a (vl-modinstlist-fix x)) (not (member-equal (vl-modinst->instname a) (string-list-fix names))))))
Theorem:
(defthm subsetp-equal-of-vl-delete-modinsts-by-instname (subsetp-equal (vl-delete-modinsts-by-instname names x) (vl-modinstlist-fix x)))
Theorem:
(defthm vl-delete-modinsts-by-instname-when-atom-of-names (implies (atom names) (equal (vl-delete-modinsts-by-instname names x) (vl-modinstlist-fix (list-fix x)))))
Theorem:
(defthm vl-slow-delete-modinsts-by-instname-removal (equal (vl-slow-delete-modinsts-by-instname names x) (vl-delete-modinsts-by-instname names x)))
Theorem:
(defthm vl-fast-delete-modinsts-by-instname-removal (equal (vl-fast-delete-modinsts-by-instname names fal x nrev) (append nrev (vl-delete-modinsts-by-instname names x))))
Theorem:
(defthm vl-delete-modinsts-by-instname-of-string-list-fix-names (equal (vl-delete-modinsts-by-instname (string-list-fix names) x) (vl-delete-modinsts-by-instname names x)))
Theorem:
(defthm vl-delete-modinsts-by-instname-string-list-equiv-congruence-on-names (implies (str::string-list-equiv names names-equiv) (equal (vl-delete-modinsts-by-instname names x) (vl-delete-modinsts-by-instname names-equiv x))) :rule-classes :congruence)
Theorem:
(defthm vl-delete-modinsts-by-instname-of-vl-modinstlist-fix-x (equal (vl-delete-modinsts-by-instname names (vl-modinstlist-fix x)) (vl-delete-modinsts-by-instname names x)))
Theorem:
(defthm vl-delete-modinsts-by-instname-vl-modinstlist-equiv-congruence-on-x (implies (vl-modinstlist-equiv x x-equiv) (equal (vl-delete-modinsts-by-instname names x) (vl-delete-modinsts-by-instname names x-equiv))) :rule-classes :congruence)