并发处理 优先图和多重图

news2024/11/23 11:40:49

    • 优先图(Precedence Graph)
    • 视图可串性
    • 多重图(Polygraph)

优先图(Precedence Graph)

优先图用于冲突可串性的判断。

优先图结构:

  • 结点 (Node):事务;
  • 有向边 (Arc): Ti → Tj ,满足 Ti <s Tj;

存在Ti中的操作A1和Tj中的操作A2,满足A1在A2前,并且A1和A2是冲突操作(对同一个元素进行:读写、写读、写写)。

在这里插入图片描述

S 中,

  • 先考虑元素 A,r2(A) w2(A) r3(A) w3(A),很明显,r2(A) 和 w3(A) 、w2(A) 和 w3(A) 是冲突操作,所以画一条有向边,从 T2 指向 T3。
  • 再考虑元素 B,r1(B) w1(B) w2(B),r1(B) 和 w2(B)、w1(B) 和 w2(B) 是冲突操作,所以画一条有向边,从 T1 指向 T2。

在这里插入图片描述

给定一个调度S,构造S的优先图P(S),若P(S)中无环,则S满足冲突可串性。

视图可串性

在这里插入图片描述

在这里插入图片描述

如果按照conflict serializability,S1不可串,实际上S1可串。View serializability 解决了 Conflict serializability 过于严格这一问题。

S1和S2中任何事务的读操作的源都相同。

在这里插入图片描述

区别:

在这里插入图片描述

多重图(Polygraph)

视图可串性判断:多重图 (Polygraph)。
对于调度Z,其Polygraph为LP(Z)。

结构:

  • Node:事务+假想的事务Tb和Tf
  • Arcs:事务(包括Tb和Tf)之间

(1) Tb对所有DB元素执行写操作,构成DB初始状态
(2) Tf读所有DB元素,得到DB终态
(3) 建立Arcs

(3a) If wi(A) ⇒ rj(A) in S, add Ti → Tj

(3b) For each wi(A) ⇒ rj(A) do
consider each wk(A): [Tk ≠Tb]
- If Ti ≠Tb ∧ Tj ≠Tf then insert
Tk → Ti some new p
Tj → Tk
- If Ti =Tb ∧ Tj ≠Tf then insert
Tj → Tk
- If Ti ≠Tb ∧ Tj =Tf then insert
Tk → Ti

(3c) 对于每一对 Ti → Tj, 选择其中一个,将其在Polygraph中删除,
如果能使Polygraph成为无环图,则调度S是视图可串化的 (V-S)

在这里插入图片描述

在这里插入图片描述

多重图画法步骤

  • 先找出所有的 写->读 操作,注意读的是源头。wb(A)->r1(A),w2(A)->r3(A),w3(A)->rf(A) 这三对如红线所示,注意 wb(A) r3(A) 并不是一对,因为 r3(A) 读的源头是 w2(A) 而不是 wb(A)。
  • 再根据上一步找出的 写->读 操作,对每一个 写->读,找出所有其他事务中的写操作,
    – 如果写是 wb,如 wb(A)->r1(A),那么除了 wb(A) 以外其他对元素 A 的写操作有 w2(A),w3(A),由于 wb(A)->r1(A) 中 T1 是作为 “接收” 的一方,所以接下来由 T1 “发送” 到其他写的事务,即从 T1->T2,T1->T3。如图中绿色线所示。
    – 如果读是 rf,如 w3(A)->rf(A),那么除了 w3(A) 和 wb(A) 以外其他对元素 A 的写操作有 w1(A),w2(A),由于 w3(A)->rf(A) 中 T3 是作为 “发送” 的一方,所以接下来由 T3 “接收” 来自其他写的事务,即从 T1->T3,T2->T3。如图中紫色线所示。
    – 如果写不是 wb,读不是 rf,如 w2(A)->r3(A),那么除了 w2(A) 和 wb(A) 以为其他对元素 A 的写操作有 w1(A),w3(A),由于 w2(A)->r3(A) 中 T2 是 “发送” 的一方,所以接下来由 T2 “接收” 来自其他写的事务,即从 T1->T2,注意标号不为 0,为 1。此外 w2(A)->r3(A) 中 T3 是 “接收” 的一方,所以接下来由 T3 “发送” 到其他写的事务,即从 T3->T1,注意标号不为 0,为 1。如图中黑色线所示。

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

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

相关文章

43、nginx的优化、防盗链、重定向、代理

nginx的优化、防盗链、重定向、代理 一、nginx的优化 1.1、隐藏版本号 server_tokens off;隐藏版本号 [roottest1 conf]# vim nginx.confserver_tokens off;[roottest1 conf]# nginx -t nginx: the configuration file /usr/local/nginx/conf/nginx.conf syntax is ok ngin…

机器学习训练之使用静态图加速

前言 MindSpore有两种运行模式&#xff1a;动态图模式和静态图模式。默认情况下是动态图模式&#xff0c;也可以手工切换为静态图模式。 动态图模式 动态图的特点是计算图的构建和计算同时发生&#xff0c;符合Python的解释执行方式。在调试模型时较为方便&#xff0c;能够实…

科大讯飞-群聊对话角色要素提取:不微调范式模拟官网评分

不微调范式模拟官网评分 step1: 模型api配置及加载测试step2: 数据加载与数据分析&#xff1a;测试集分析:step3: prompt设计:step4 :大模型推理&#xff1a;step 5: 结果评分测试&#xff1a;评分细则&#xff1a;评估指标 参考&#xff1a; 比赛说明&#xff1a; #AI夏令营 #…

从打印到监测:纳米生物墨水助力3D生物打印与组织监测平台?

从打印到监测&#xff1a;纳米生物墨水助力3D生物打印与组织监测平台&#xff1f; 在 3D 组织工程中&#xff0c;纳米生物墨水是将纳米材料与 ECM 水凝胶结合&#xff0c;以提高其打印性和功能性的重要策略。纳米生物墨水可以增强水凝胶的机械性能、导电性、生物活性&#xff…

【Transformer】transformer模型结构学习笔记

文章目录 1. transformer架构2. transformer子层解析3. transformer注意力机制4. transformer部分释疑 图1 transformer模型架构 图2 transformer主要模块简介 图3 encoder-decoder示意图N6 图4 encoder-decoder子层示意图 1. transformer架构 encoder-decoder框架是一种处理NL…

卷积神经网络基础篇

文章目录 1、卷积层1.1、激活函数1.3、sigmoid1.4、Tanh1.5、ReLU1.6、Leaky ReLU1.7、误差计算 2、池化层3、全连接层4、CNN训练 参考链接1 参考链接2 1、卷积层 卷积层&#xff08;Convolutional layer&#xff09;&#xff0c;这一层就是卷积神经网络最重要的一个层次&…

数据库的学习(4)

一、题目 1、创建数据表qrade: CREATE TABLE grade(id INT NOT NULL,sex CHAR(1),firstname VARCHAR(20)NOT NULL,lastname VARCHAR(20)NOT NULL,english FLOAT,math FLOAT,chinese FLOAT ); 2、向数据表grade中插入几条数据: (3,mAllenwiiliam,88.0,92.0 95.0), (4,m,George&…

java版企业工程管理系统源码:全方位的项目管理解决方案

工程管理系统是一款专注于建设工程项目全生命周期管理的软件。它覆盖了项目从策划、设计、施工到竣工的每一个阶段&#xff0c;提供全方位的管理功能。系统采用模块化设计&#xff0c;包括系统管理、系统设置、项目管理、合同管理、预警管理、竣工管理、质量管理、统计报表和工…

centos7.9 rpm包安装mysql8.2.0数据库、root设置客户端登录、配置并发、表名大小写敏感、启动重启指令等记录

centos安装mysql8数据库,下载的是rpm-bundle.tar包,这样可以在内网环境离线安装,工作中医院的服务器很多也是内网的,所以这里记录下rpm-bundle.tar包安装的步骤。 lscpu 查看处理器是x86还是arm 下载对应的版本 bundle tar包 ((mysql-8.2.0-1.el7.x86_64.rpm-bundle.tar))…

打造属于你的私人云盘:在 OrangePi AIpro 上搭建个人云盘

随着数字化时代的到来&#xff0c;数据的存储和管理变得愈发重要。相比于公共云存储服务&#xff0c;搭建一个属于自己的个人云盘不仅能够更好地保护隐私&#xff0c;还可以更灵活地管理数据。 近期刚好收到了一个 香橙派 AIpro 的开发板&#xff0c;借此机会用来搭建一个属于…

《算法笔记》总结No.4——散列

散列的英文名是hash&#xff0c;即我们常说的哈希~该知识点在王道408考研的教材里面属于查找的范围。即便各位并无深入了解过&#xff0c;也听说过散列是一种更高效的查找方法。 一.引例 先来考虑如下一个假设&#xff1a;设有数组M和N分别如下&#xff1a; M[10][1,2,3,4,5,6…

idea 默认路径修改

1.查看 idea 的安装路径&#xff08;右键点击 idea 图标&#xff0c;查看路径 &#xff09; “C:\Program Files\JetBrains\IntelliJ IDEA 2021.3.1\bin\idea64.exe” 在 bin 目录查看 idea.properties 文件&#xff0c;修改以下四个路径文件 # idea.config.path${user.home}/…

对话大模型Prompt是否需要礼貌点?

大模型相关目录 大模型&#xff0c;包括部署微调prompt/Agent应用开发、知识库增强、数据库增强、知识图谱增强、自然语言处理、多模态等大模型应用开发内容 从0起步&#xff0c;扬帆起航。 基于Dify的QA数据集构建&#xff08;附代码&#xff09;Qwen-2-7B和GLM-4-9B&#x…

QT入门笔记-自定义控件封装 30

具体代码如下: QT core guigreaterThan(QT_MAJOR_VERSION, 4): QT widgetsCONFIG c17# You can make your code fail to compile if it uses deprecated APIs. # In order to do so, uncomment the following line. #DEFINES QT_DISABLE_DEPRECATED_BEFORE0x060000 …

uni-app使用ucharts地图,自定义Tooltip鼠标悬浮显示内容并且根据@getIndex点击事件获取点击的地区下标和地区名

项目场景&#xff1a; uni-app使用ucharts地图,自定义Tooltip鼠标悬浮显示内容并且根据getIndex点击事件获取点击的地区下标和地区名 例如&#xff1a; 问题描述 官方给的文档有限&#xff0c;需要自己下载地图json数据然后自己渲染和编写鼠标悬浮显示内容以及获取点击地址…

【ComfyUI节点】扰动注意力引导Perturbed Attention Guidance

扰动注意力引导 Perturbed Attention Guidance GitHub - KU-CVLAB/Perturbed-Attention-Guidance: Official implementation of "Perturbed-Attention Guidance" 按照官方介绍&#xff0c;扰动注意力指导显著提高了扩散模型的样本质量&#xff0c;而无需外部条件&am…

代码随想录第45天|动态规划

300.最长递增子序列 参考 dp[i] 表示以 i 为结尾的最长递增子序列长度递推公式: 使用 i 和 j 判断 dp[i] max(dp[j] 1, dp[i])每次 j 都需要从头遍历 初始化: dp[i] 1 class Solution { public:int lengthOfLIS(vector<int>& nums) {vector<int> dp(nums…

鸿蒙开发:Universal Keystore Kit(密钥管理服务)【明文导入密钥(C/C++)】

明文导入密钥(C/C) 以明文导入ECC密钥为例。具体的场景介绍及支持的算法规格 在CMake脚本中链接相关动态库 target_link_libraries(entry PUBLIC libhuks_ndk.z.so)开发步骤 指定密钥别名keyAlias。 密钥别名的最大长度为64字节。 封装密钥属性集和密钥材料。通过[OH_Huks_I…

实现antd designable平台的组件拖拽功能

平台&#xff1a;designable设计器 github&#xff1a;designable 目录 1 背景2 技术栈3 组件拖拽和放置3.1 类型定义3.2 拖拽3.3 放置 1 背景 由于业务需求&#xff0c;我们需要实现designable平台的一个简易版的组件拖拽功能。 #mermaid-svg-QrxSDGe9YyGG3LbQ {font-family:…

andboxie-Plus - 知名沙盒软件、支持游戏多开测试软件

我们经常会需要用到一些毒瘤软件——它们可能不是真正的恶意软件&#xff0c;但总爱偷摸干一些流氓行为。 工作中&#xff0c;有时还不得不安装使用一些来路不明、不能完全信任的可疑软件。 装上吧&#xff0c;心里膈应、难受&#xff1b;不装吧&#xff0c;有些工作又进行不…