逻辑优化基础-disjoint support decomposition

news2024/11/26 13:40:39

先遣兵

在了解 disjoint support decomposition 之前,先学习两个基本的概念。

  • disjoint

数学含义上的两个集合交集,所谓非相交,即交集为空集。

A ∩ B = C = ⊘ A \cap B = C = \oslash AB=C=
在这里插入图片描述

  • support

逻辑综合中的 s u p p o r t support support 概念是指: 一个门 g g g s u p p o r t support support 是指该门 g g g 的所有原始输入 P I PI PI

例如有一个函数:
F o u t = h ( x ) + g ( x ) Fout = h(x) + g(x) Fout=h(x)+g(x)
其中 h ( x ) = A + B h(x) = A + B h(x)=A+B g ( x ) = D + E g(x) = D + E g(x)=D+E,则 n o d e node node h h h g g g s u p p o r t support support 分别为 { A, B }、{ D, E }, F o u t Fout Fout s u p p o r t support support 为 { A, B, D, E }。

其他概念有兴趣可参考 逻辑综合知识点总结 持续更新中…

1. 简介

disjoint support decomposition ,它是用于优化布尔函数的一种技术,将其分解成具有不交 s u p p o r t support support 的较小子函数。

一个布尔函数可以表示为 (sum of products,SOP)表达式或积和式(product of sums,POS)表达式。

disjoint support decomposition 的目的是将给定表达式转换为具有较小且更易于处理的子表达式的形式。它的基本思想是识别原始表达式中没有共同变量的变量子集,并将表达式分解为只取决于这些子集的较小表达式的和。这使得函数更容易进行优化,因为较小的表达式通常更容易处理。

即:

非相交分解 == 一个函数 F F F可以被子函数 K K K J J J 表示,且 K K K J J J s u p p o r t support support 不相交,且 4J$ 只有一个输出,
F = K ( x 1 , x 2 , . . . , x j − 1 , J ( x j , . . . , x n ) ) F = K (x_1, x_2, ..., x_{j-1}, J(x_j, ..., x_n)) F=K(x1,x2,...,xj1,J(xj,...,xn))
例如有一个函数:
F = ( x 1 + x 2 ) ( x 3 ⊕ x 4 ) F = (x_1 + x_2)(x_3 \oplus x_4) F=(x1+x2)(x3x4)
最简单的 d s d dsd dsd 为图 (a) 所示:
K = ( x 3 ⊕ x 4 ) J 1 , J 1 = ( x 1 + x 2 ) K = (x_3 \oplus x_4)J_1, J_1 = (x_1 + x_2) K=(x3x4)J1,J1=(x1+x2)
或者图 (b):
K = ( x 1 + x 2 ) J 2 , J 2 = ( x 3 ⊕ x 4 ) K = (x_1 + x_2)J_2, J_2 = (x_3 \oplus x_4) K=(x1+x2)J2,J2=(x3x4)
再进一步表示为图 © F = K ( J 1 , J 2 ) = ( x 1 + x 2 ) ( x 3 ⊕ x 4 ) F = K(J_1, J_2) = (x_1 + x_2)(x_3 \oplus x_4) F=K(J1,J2)=(x1+x2)(x3x4)

在这里插入图片描述
如果一个 o u t p u t output output 被全部用 d s d dsd dsd 表示,这意味着拿掉某一个 s u p p o r t support support 不会对其他的 s u p p o r t support support 支持的逻辑造成影响,个人理解是否可以通过 d s d dsd dsd 分解由局部最优达到全局最优。

如果 F F F被一个 D A G ( G ) DAG(G) DAG(G) 表示的话,也可以表示为,应该比较容易理解:
E d g e ( G ) = E d g e ( K ) + E d g e ( J ) Edge(G) = Edge(K) + Edge(J) Edge(G)=Edge(K)+Edge(J)

2. 算法

TODO

3. 优点

TODO

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/403026.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

【创建“待选项”按钮02计算坐标 Objective-C语言】

一、之前,我们已经把“待选项”按钮,创建好了,但是唯一的问题是,坐标都是一样的,所以都显示在一起了 1.下面,我们来设置一下,这些“待选项”按钮的坐标, 现在,“待选项”按钮的坐标,是不是都在同一个位置啊, 回忆一下,这个待选项按钮,是怎么生成的, 首先,是在…

PCA-APCA-MLR

全称 principal component analysis-absolute principal component score-multiple linear regression 原理 绝对因子分析/多元线性回归受体模型(APCS—MLR)的基本原理是将因子分析的主因子得分转化为绝对主因子得分(APCS),各指标含量再分别对所有的APCS进行多元线性回…

课程作业及比赛任务,已支持 Notebook 内直接提交|ModelWhale 版本更新

早春时节、万物复苏,我们又迎来了 ModelWhale 新一轮的版本更新。本次更新中,ModelWhale 主要进行了以下功能迭代:新增 Notebook 内提交课程作业及比赛任务(团队版✓ )新增 Canvas 组件停止维护提示(团队版…

44-Golang中的channel

Golang中的channel为什么要使用channelchannel的介绍channel的基本使用定义/声明channel管道的遍历和关闭channel的关闭channel的遍历goroutine和channel结合应用实例1应用实例2案例注意事项为什么要使用channel 前面使用全局变量加锁同步来解决goroutine的通讯,但…

设计模式—适配器模式

适配器模式(Adapter Pattern)是作为两个不兼容的接口之间的桥梁。这种类型的设计模式属于结构型模式,它结合了两个独立接口的功能。这种模式涉及到一个单一的类,该类负责加入独立的或不兼容的接口功能。举个真实的例子&#xff0c…

【操作系统】如何排查死锁?

【操作系统】如何排查死锁? 文章目录【操作系统】如何排查死锁?死锁的概念死锁的排查工具排查工具 1:jstack排查工具 2:jconsole死锁的发生条件互斥条件持有并等待条件不可剥夺条件环路等待条件避免死锁问题的发生总结死锁的概念 …

TCP、UDP

TCP和UDPTCP报头三次握手,四次挥手确认机制(重传ARQ)重传机制拥塞控制(慢开始-拥塞避免,快重传、快恢复)流量控制(滑动窗口)差错控制(校验和)UDP报头TCP和UDP…

Qt之高仿QQ系统设置界面

QQ或360安全卫士的设置界面都是非常有特点的,所有的配置项都在一个垂直的ScrollArea中,但是又能通过左侧的导航栏点击定位。这样做的好处是既方便查看指定配置项,又方便查看所有配置项。 一.效果 下面左边是当前最新版QQ的系统设置界面,右边是我的高仿版本,几乎一毛一样…

JVM初步理解浅析

一、JVM的位置 JVM的位置 JVM在操作系统的上一层,是运行在操作系统上的。JRE是运行环境,而JVM是包含在JRE中 二、JVM体系结构 垃圾回收主要在方法区和堆,所以”JVM调优“大部分也是发生在方法区和堆中 可以说调优就是发生在堆中&#xf…

国外seo比较好的优化方法有哪些?

随着互联网的不断发展,SEO(搜索引擎优化)变得越来越重要。 对于国外市场,Google搜索引擎是最为重要的搜索引擎之一, 因此在优化国外网站时,需要将Google SEO优化作为首要任务。 关键词研究和优化 在进行…

Windows逆向安全(一)C与汇编的关系

前言 逆向是一种新型的思维模式也是软件开发领域中极为重要的技术,涵盖各种维度去深挖软件架构的本质和操作系统原理,学习逆向后可以在各领域中发挥至关重要的作用,其中包括黑灰色,安全开发,客户端安全,物…

没有对象感,沟通太费劲

沟通中最重要的感觉:对象感! 要沟通的是谁?以啥方式最好? 趣讲大白话:蹲着跟小孩说话 【趣讲信息科技100期】 ******************************* 对象感是沟通者必须训练和提升的 是换位思考的一种能力 以便跟沟通对象进…

【虚拟工厂】SCL编写<机械手加盖模块>应用

使用scl来编写实虚拟工场中的一个机械手加盖应用项目 文章目录 目录 文章目录 前言 1.机械手加盖场景 2.了解各部分功能 3.命名变量找出输入输出 4.在博图建立变量 二、编写思路 1.分析 2.使用小模块化来编写 3.确定编程思路 三、编程 1.上料部分 2.机械手部分 3…

【数据结构】线性表和顺序表

Yan-英杰的主页 悟已往之不谏 知来者之可追 目录 1.线性表 2.顺序表 2.1 静态顺序表 2.2 动态顺序表 2.3移除元素 1.线性表 线性表(linear list)是n个具有相同特性的数据元素的有限序列。 线性表是一种在实际中广泛使用的数据结构,常见的线…

新C++(14):移动语义与右值引用

当你在学习语言的时候,是否经常听到过一种说法,""左边的叫做左值,""右边的叫做右值。这句话对吗?从某种意义上来说,这句话只是说对了一部分。---前言一、什么是左右值?通常认为:左值是一个表示数据的表达式(…

Git版本控制管理

Git日志记录查看日志获取执行过的命令查看每一次提交记录比较文件差异还原文件git远程仓库克隆远程仓库移除无效的远程仓库Git远程仓库推送、抓送,和拉取Git远程仓库多人协作冲突问题Git远程仓库SSH协议推送Git分支查看分支创建分支修改分支切换分支推送至远程仓库分…

Python3实现“美颜”功能

导语利用Python实现美颜。。。这是之前在GitHub上下载的一个项目。。。似乎有些日子了。。。所以暂时找不到原项目的链接了。。。今天抽空看了下它源代码的主要思想,似乎挺简单的。。。于是决定用Python3自己复现一下。。。T_T感觉还是挺有趣的。。。Just have a tr…

源码分析Spring @Configuration注解如何巧夺天空,偷梁换柱。

前言 回想起五年前的一次面试,面试官问Configuration注解和Component注解有什么区别?记得当时的回答是: 相同点:Configuration注解继承于Component注解,都可以用来通过ClassPathBeanDefinitionScanner装载Spring bean…

IT服务发布管理过程文件

目的 规范发布管理的提交、审批、沟通、测试、回滚、实施等活动。 范围 适用于我公司的IT服务管理重大变更的内、外部发布。 术语定义 发布:将一个或多个变更交付、分发到实际运行环境中并可对其进行追溯。非项目的IT服务重大变更需要遵循本过程进行发布。发布主要包…

论文投稿指南——中文核心期刊推荐(工业经济)

【前言】 🚀 想发论文怎么办?手把手教你论文如何投稿!那么,首先要搞懂投稿目标——论文期刊 🎄 在期刊论文的分布中,存在一种普遍现象:即对于某一特定的学科或专业来说,少数期刊所含…