笛卡尔乘积c语言代码,c# – 高效笛卡尔乘积算法

有人可以向我证明比目前使用的笛卡儿乘积算法更有效(假设有一个)。我已经看了周围的SO和谷歌,但看不到任何明显的东西,所以我可能会缺少一些东西。

foreach (int i in is) {

foreach (int j in js) {

//Pair i and j

}

}

这是我在代码中做的非常简化的版本。两个整数是用于检索一个/多个对象的查找键,并且来自两个查找的所有对象都被配对在一起成为新对象。

这个小型的代码块在一个更大的更复杂的系统中成为主要的性能瓶颈,因为它在规模上运行的数据集。其中一些可能通过改进用于存储对象的数据结构和所涉及的查找来缓解,但是我觉得仍然是笛卡尔乘积本身的计算的主要问题。

编辑

所以有更多的背景我的具体使用的算法,看看是否可能有任何技巧,我可以用来回应Marc的评论。整个系统是一个SPARQL查询引擎,它通过图形数据集来处理SPARQL查询,SPARQL是一种基于模式的语言,因此每个查询由一系列与图形匹配的模式组成。在两个后续模式没有共同变量(它们不相交)的情况下,有必要计算由两个模式产生的解的笛卡尔积,以获得用于整体查询的可能解的集合。可能有任何数量的模式,我可能需要多次计算笛卡尔乘积,如果查询由一系列不相交的模式组成,这可能导致可能的解决方案中相当指数的扩展。

不知怎的,从现有的答案我怀疑是否有任何技巧可以应用

更新

所以我以为我会发布一个更新我实现了为了最小化笛卡尔积分产品的需要,从而优化查询引擎一般。注意,并不总是可以完全消除对产品的需求,但是几乎总是可以进行优化,所以连接的两个组件的尺寸要小得多。

由于作为一组三重模式的每个BGP(基本图形模式)被执行为块(本质上),引擎可以自由地重新排序BGP内的模式以获得最佳性能。例如考虑以下BGP:

?a :someProperty ?b .

?c :anotherProperty ?d .

?b a :Class .

执行查询需要笛卡尔乘积,因为第一种模式的结果与第二种模式不相交,因此前两种模式的结果是其各自结果的笛卡尔乘积。这个结果将包含比我们实际需要的结果更多的结果,因为第三种模式限制了第一种模式的可能结果,但是我们以后不再应用此限制。但是如果我们重新排序如下:

?b a :Class .

?a :someProperty ?b .

?c :anotherProperty ?d .

我们仍然需要一个笛卡尔乘积来获得最终的结果,因为第2和第3种模式仍然不相交,但是通过重新排序,我们限制了第二种模式的结果的大小,这意味着我们的笛卡尔积的尺寸会小得多。

我们有一些其他的优化,但是我不会在这里发布,因为它开始对SPARQL引擎内部部分进行了详细的讨论。如果有任何人对进一步的细节感兴趣,请发表评论或给我发送tweet @RobVesse

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

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

相关文章

【音视频安卓开发 (七)】安卓视频播放窗口去掉标题栏、全屏、横屏

java中的MainActivity初始化部分设置这些操作 //去掉标题栏supportRequestWindowFeature( Window.FEATURE_NO_TITLE);//全屏,隐藏状态getWindow().setFlags( WindowManager.LayoutParams.FLAG_FULLSCREEN ,WindowManager.LayoutParams.FLAG_FULLSCREEN);//屏幕为横屏…

drools6.5_Drools 6.4.0.Final提供

drools6.5最新和最出色的Drools 6.4.0.Final版本现已可供下载。 这是我们先前构建的增量版本,对核心引擎和Web工作台进行了一些改进。 您可以在此处找到更多详细信息,下载和文档: Drools网站 资料下载 文献资料 发行说明 请阅读下面的…

python 统计组合用什么库_Python机器学习需要用到的库

www.oldboyedu.com 老男孩 IT 教育,只培养技术精英 Python 机器学习需要用到的库 Python 是一种面向对象的解释型计算机程序设计语言,具有丰富和强大的 库,再加上其简单、易学、速度快、开源免费、可移植性、可扩展性以及面向对 象的特点&…

c语言编程数学黑洞,一个数学黑洞——6174

该楼层疑似违规已被系统折叠 隐藏此楼查看此楼/*问题描述:从0-9中任意选取4个不完全相同的数比如,不能是5 5 5 5,可以是1 2 2 2用这4个数排列出最大的数,2221,最小的数1222最大减最小:2221-12220999用0 9 9…

【音视频安卓开发 (八)】OpenSLES播放音频步骤和接口讲解

OpenSLES是安卓内部的音频播放和录音 初始化引擎 创建输出设备 配置PCM格式信息 初始化播放器 播放和缓冲队列 本文开源项目下载

kata_FizzBu​​zz Kata与Java流

kata在柔道练习仅几周之后,我的儿子感到无聊。 他抱怨说自己没有学任何东西,因为他一遍又一遍地做着同样的事情。 混淆学习和做新事物的不仅是幼儿。 例如,有多少软件开发人员通过执行kata或参加dojos来进行刻意练习的麻烦? 重复…

python中if语句的实例_对python中if语句的真假判断实例详解

说明 在python中,if作为条件语句,当if后面的条件参数为真时,则执行后面的语句块,反之跳过,为了深入理解if语句,我们需要知道if语句的真假判断方式。 示例 在python交互器中,经过测试发现以下条件…

ds18b20c语言显示小数位,DS18B20多点测温(读序列,匹配序列,51单片机C程序,1602显示)...

DS18B20多点测温(读序列,匹配序列,51 C程序,1602显示)程序一:单个读序列号。程序二,匹配并且读两个DS18B20,当然,读多个与读两个基本原理一样,只要加上其序列号等即可。本程序所有显…

【WebRTC---入门篇】(五)Web服务器原理与Nodejs搭建

Web服务器工作原理 Nodejs工作原理 首先自己开发的APPLICATION(自己开发的JS程序)输出给V8引擎,解析后的二进制文件调用NODE API,然后调用LIBUV事件处理库(插入到事件队列,在队列中不断循环处理事件)。 JavaScript解析 V8引擎先收到JS程序,解析生成JS语法树,通过解析器…

代理模式和动态代理模式_代理模式介绍

代理模式和动态代理模式代表:被选中或当选为他人投票或代理的人– Merriam-Webster 。 委托模式:在软件工程中,委托模式是面向对象编程中的一种设计模式,其中,一个对象而不是执行其陈述的任务之一,而是将该…

【WebRTC---入门篇】(六)JavaScript基础

变量与类型 var与let的区别,var局部变量;let全局变量 函数

javaio流层次结构_流的多层次分组

javaio流层次结构1.简介 使用Java 8流,可以很容易地根据不同的标准对对象集合进行分组。 在这篇文章中,我们将看到如何从简单的单级分组到更复杂的,涉及多个级分组的分组。 我们将使用两个类来表示我们要分组的对象:人和宠物。 …

【开源项目----Android OPenGLES渲染YUV视频文件】

【开源项目----Android OPenGLES渲染YUV视频文件】 OpenGLES对YUV渲染相关文章参考

大型程序是如何开发的_大型小程序如何研发提效

作者:王梦君微信公众号:滴滴顺风车技术出处:https://mp.weixin.qq.com/s/M1VArJ_ORY-eXSKzD6ysQw导读:自2016年小程序诞生以来,小程序以其“用完即走”的设计理念,以及简单易上手的开发模式,吸引了大批的小程序使用者以及开发者&a…

c 语言栈,C语言栈

C语言实现简单的栈结构今天看到一个问题是要交换两个变量的值并且不能使用中间变量,首先想到的方法就是用数学的方法:int a 10,b 12;a a b; // 求和b a - b; // 和减去b得到的是a的值a a - b; // 和减去a(此时的b是最初a的值)得到b 的值这种方法很…

【WebRTC---入门篇】(七)MediaStream

MediaStream方法 MediaStream.addTrack( ) 功能:向流媒体中加入不同的轨 MediaStream.removeTrack( ) 功能:从流媒体中移除不同的轨 MediaStream.getVideoTracks( ) 功能:从流媒体中取出所有的视频轨 MediaStream.getAudioTracks( …

jvm 宕机 打印jvm_通过入侵JVM打印阵列

jvm 宕机 打印jvm总览 Java中最常见的陷阱之一就是知道如何打印数组。 如果有关如何打印阵列的答案获得了超过1000票赞成票,那么您必须怀疑是否有更简单的方法。 几乎所有其他流行语言都具有这种更简单的方法,所以我不清楚为什么Java仍会这样做。 与其他…

python数码时钟代码_Python+Pyqt实现简单GUI电子时钟

本文实例为大家分享了PythonPyqt实现简单GUI电子时钟的具体代码,供大家参考,具体内容如下 突发奇想想用GUI做一个简单的电子时钟界面,利用pyqt模块也很方便,代码如下: from PyQt5.QtGui import * from PyQt5.QtCore im…

两个人投票的c语言程序,设计网页投票器(二)《精通Unix下C语言编程与项目实践》之十...

本处设计一个网页投票器,它访问“www.zhiliaowang.com”上的服务程序“/toupiaoceshi.asp”,并通过“name”参数向选手投票。如代码15-16所示:代码15-16网页投票器(节自/code/chapter15/http1.c)#include char buf2[]/*组装HTTP协议GET请求报…

【WebRTC---入门篇】(八)WebRTC核心之RTP Medio 媒体控制与数据统计

RTCPeerConnection底层是通过RTP Medio实现的,处理真正数据传输,编码流量各种控制的实现。 Receiver 通过 getReceivers 可以获取一组RTCRtpReceiver对象,用于接收数据 Sender 通过getSenders 可以获取一组RTCRtpSender对象,用于发送数据,每个对象对应一个媒体轨 RTCR…