当前位置: 首页 > news >正文

基于贝叶斯决策的 CAD 程序设计方案

在这里插入图片描述

✅作者简介:2022年博客新星 第八。热爱国学的Java后端开发者,修心和技术同步精进。
🍎个人主页:Java Fans的博客
🍊个人信条:不迁怒,不贰过。小知识,大智慧。
💞当前专栏:Java案例分享专栏
✨特色专栏:国学周更-心性养成之路
🥭本文内容:基于贝叶斯决策的 CAD 程序设计方案

文章目录

    • 一、前言
    • 二、什么是贝叶斯决策?
    • 三、实现步骤
      • 1. 定义问题和数据
      • 2. 收集先验概率
      • 3. 设计特征提取
      • 4. 应用贝叶斯定理
      • 5. 决策规则
      • 6. 实现算法
      • 7. 编程实现
      • 8. 测试和验证
      • 9. 部署和维护
    • 四、总结

一、前言

  在CAD(计算机辅助设计)程序设计中,贝叶斯决策作为一种强大的决策方法,为设计师和工程师提供了处理不确定性和风险的有效工具。通过结合贝叶斯理论和决策分析技术,CAD系统可以更好地应对设计过程中的各种挑战,从而实现更高效、更优化的设计方案。

  本文旨在探讨贝叶斯决策在CAD程序设计中的应用,介绍贝叶斯决策的基本原理和方法,并探讨如何将其应用于CAD系统的设计过程中。我们将深入研究贝叶斯网络模型的建立、数据搜集、推断和决策等关键步骤,以及如何通过贝叶斯决策优化CAD系统的设计,提高设计效率和质量。

  通过本文的阐述,读者将能够更好地理解贝叶斯决策在CAD程序设计中的重要性和应用前景,为设计领域的专业人士提供有益的参考和启发。让我们一起探索贝叶斯决策如何为CAD程序设计带来新的思路和方法,推动设计过程向着更加智能化和优化化的方向发展。

二、什么是贝叶斯决策?

  贝叶斯决策是一种基于贝叶斯理论的决策方法,它通过考虑不确定性和风险,帮助决策者做出最优的决策。在贝叶斯决策中,决策者会基于已有的信息和先验概率,利用贝叶斯定理来更新概率,并计算出每个可能决策的后验概率,然后选择具有最大后验概率的决策。

具体来说,贝叶斯决策包括以下几个关键步骤:

  • 建立模型:首先,需要建立一个数学模型来描述决策问题,包括决策变量、状态变量、不确定性因素等。这可以通过贝叶斯网络、决策树等方法来实现。

  • 确定先验概率:在没有观测到新数据之前,需要确定各种不确定性因素的先验概率分布。这可以基于历史数据、专家知识或者主观判断来确定。

  • 观测数据:当观测到新数据时,根据贝叶斯定理,可以更新先验概率,得到后验概率。这个过程被称为贝叶斯推断。

  • 计算期望损失:对于每个可能的决策,可以计算出在不同情况下的期望损失,即在考虑不确定性的情况下,每个决策的平均损失。

  • 选择最优决策:最后,根据后验概率和期望损失,选择具有最小期望损失的决策作为最优决策。

  贝叶斯决策方法在处理不确定性和风险时具有很好的效果,可以帮助决策者在复杂的环境中做出理性的决策。

三、实现步骤

1. 定义问题和数据

  我们考虑了一个疾病分类的情况,其中包括健康状态 ω0 和其他 m 个疾病类别 ω1, ω2, …, ωm。每个疾病类别都有特定的体征和症状,我们用 x1, x2, …, xn 来表示这些体征和症状,其中 n ≥ 8。

具体来说,我们可以将问题定义如下:

  • 疾病类别:包括健康状态 ω0 和其他 m 个疾病类别 ω1, ω2, ..., ωm,共计 m+1 个类别。
  • 体征和症状:每个疾病类别都有一组特定的体征和症状,用 x1, x2, ..., xn 表示,其中 n ≥ 8。这些体征和症状可以是生理指标、临床表现、实验结果等。

  在实际应用中,我们可以收集关于不同疾病类别下体征和症状的数据,以建立一个贝叶斯网络模型或者决策模型,帮助医生或专业人士根据患者的体征和症状来进行疾病分类和诊断。通过分析这些数据,我们可以更好地理解不同疾病之间的关联性,提高疾病诊断的准确性和效率。

2. 收集先验概率

  我们需要收集疾病类别 ωi 的先验概率 P(ωi) 和在每个疾病类别条件下体征 xi 出现的条件概率 P(xi|ωi)。这些概率是贝叶斯决策过程中非常重要的信息,可以帮助我们进行后续的推断和决策。

具体来说,我们可以进行以下步骤来收集先验概率和条件概率:

  • 先验概率 P(ωi):先验概率是指在没有任何其他信息的情况下,疾病类别 ωi 出现的概率。这些先验概率可以通过历史数据、流行病学调查、医学文献等渠道来获取。例如,可以统计过去一段时间内不同疾病的发病率,从而估计每种疾病的先验概率。

  • 条件概率 P(xi|ωi):条件概率是指在已知患有疾病类别 ωi 的情况下,体征 xi 出现的概率。这些条件概率可以通过临床研究、医学实验、专家知识等途径来获取。医生和专业人士可以根据临床经验和研究结果,估计不同疾病类别下各种体征和症状的条件概率。

  通过收集先验概率和条件概率,我们可以建立一个贝叶斯网络模型或者决策模型,用于疾病诊断和分类。这些概率信息可以帮助我们在面对患者的具体体征和症状时,根据贝叶斯决策方法进行推断和决策,提高诊断的准确性和效率。

3. 设计特征提取

  在设计特征提取过程时,我们需要从患者的体征和症状中提取关键特征,这些特征可以帮助我们更好地进行疾病分类和诊断。这些特征可以是各种生理指标、临床表现、实验结果等,例如血压、体重、化验结果等。下面是一些详细阐述:

  • 生理指标:生理指标是反映患者生理状态的重要特征,包括血压、体温、心率、呼吸频率等。这些指标可以通过医疗仪器和设备进行测量,提供客观的数据支持。

  • 临床表现:患者的临床表现也是重要的特征之一,包括疼痛部位、症状持续时间、病史等。医生可以通过询问患者或观察患者的表现来获取这些信息。

  • 实验结果:实验结果可以提供更精确的数据支持,包括血液化验、尿液检查、影像学检查等。这些结果可以帮助医生更准确地了解患者的病情和疾病类型。

  在特征提取过程中,我们需要根据疾病的特点和诊断需求,选择合适的特征进行提取和分析。特征提取的目的是从原始数据中提取出最具有代表性和区分性的特征,以帮助我们进行后续的数据分析和决策。

  通过设计合适的特征提取过程,我们可以将患者的体征和症状转化为可量化和可分析的特征向量,为贝叶斯决策模型提供输入数据,从而实现更准确和高效的疾病诊断和分类。

4. 应用贝叶斯定理

  在应用贝叶斯定理进行疾病诊断时,我们需要计算每个可能的疾病类别 ωi 的后验概率 P(ωi|x),其中 x 是患者的体征和症状。贝叶斯定理可以表示为:

[ P(\omega_i|x) = \frac{P(x|\omega_i)P(\omega_i)}{P(x)} ]

其中,P(x) 是证据因子,表示在所有可能的疾病类别下观察到体征和症状 x 的概率。我们可以通过全概率公式计算 P(x):

[ P(x) = \sum_{i=0}^m P(x|\omega_i)P(\omega_i) ]

具体步骤如下:

  • 计算证据因子 P(x):首先,我们需要计算在所有可能的疾病类别下观察到体征和症状 x 的概率。根据全概率公式,我们可以将每个疾病类别下观察到 x 的概率加总起来,得到 P(x)。

  • 计算后验概率 P(ωi|x):接下来,对于每个可能的疾病类别 ωi,我们可以利用贝叶斯定理计算后验概率 P(ωi|x)。根据贝叶斯定理,我们将条件概率 P(x|ωi)、先验概率 P(ωi) 和证据因子 P(x) 带入公式中,即可计算出后验概率。

  通过计算后验概率,我们可以评估在观察到特定体征和症状 x 的情况下,每种疾病类别的概率大小,从而进行疾病诊断和分类。后验概率越大,表示该疾病类别的可能性越高。贝叶斯定理的应用可以帮助我们结合先验知识和观测数据,进行合理的推断和决策,提高疾病诊断的准确性和可靠性。

5. 决策规则

  在贝叶斯决策中,决策规则的核心是选择具有最高后验概率的疾病类别作为最终的诊断结果。具体而言,我们可以通过以下方式来确定诊断结果:

  • 计算后验概率:首先,根据贝叶斯定理计算每个可能的疾病类别 ωi 的后验概率 P(ωi|x),这表示在观察到患者的体征和症状 x 后,每种疾病类别的概率。

  • 选择最高后验概率:在计算完所有可能的疾病类别的后验概率后,我们可以通过以下决策规则来确定最终的诊断结果:
    [ \omega^* = \arg\max_i P(\omega_i|x) ]

  • 这意味着我们选择具有最高后验概率的疾病类别 ω* 作为最终的诊断结果。换句话说,我们选择在给定患者体征和症状 x 的情况下,最有可能导致这些体征和症状的疾病类别。

  通过这样的决策规则,我们可以根据贝叶斯推断的结果,选择最可能的疾病类别作为诊断结果,从而为患者提供准确的诊断和治疗方案。这种基于后验概率的决策规则可以帮助医生和专业人士在面对复杂的疾病诊断问题时做出理性和可靠的决策。

6. 实现算法

  为实现基于贝叶斯决策的疾病诊断算法,我们可以按照以下步骤进行:

输入: 患者的体征和症状数据。

  • 特征提取:从患者的体征和症状数据中提取特征,包括生理指标、临床表现、实验结果等。这些特征可以帮助我们量化患者的病情信息,为后续的计算提供输入。

  • 计算后验概率:对于每个可能的疾病类别 ωi,根据贝叶斯定理计算后验概率 𝑃(𝜔𝑖∣𝑥)。这涉及计算每个疾病类别下观察到特征的条件概率 𝑃(𝑥∣𝜔𝑖)和先验概率 𝑃(𝜔𝑖),然后根据贝叶斯定理计算后验概率。

  • 选择最可能的疾病:比较所有疾病类别的后验概率,选择具有最高后验概率的疾病类别作为最终的诊断结果。这可以通过比较后验概率来实现,选择具有最大后验概率的疾病类别。

输出: 最可能的疾病诊断。 通过以上步骤,我们可以实现一个基于贝叶斯决策的疾病诊断算法。这种算法可以根据患者的体征和症状数据,结合先验知识和条件概率,进行合理的推断和决策,从而为患者提供准确的疾病诊断结果。

  在实际应用中,我们可以利用编程语言如Python来实现这个算法,编写特征提取函数、后验概率计算函数和诊断函数,以实现完整的疾病诊断系统。这样的系统可以帮助医生和专业人士更快速、准确地进行疾病诊断,提高医疗决策的效率和质量。

7. 编程实现

假设使用Python语言,可以使用以下伪代码来实现:

import numpy as npdef compute_posterior(prior_probabilities, likelihoods, evidence):posterior_probabilities = []for i in range(len(prior_probabilities)):posterior = (likelihoods[i] * prior_probabilities[i]) / evidenceposterior_probabilities.append(posterior)return posterior_probabilitiesdef diagnose_disease(features, prior_probabilities, likelihoods):evidence = sum(likelihoods[i] * prior_probabilities[i] for i in range(len(prior_probabilities)))posterior_probabilities = compute_posterior(prior_probabilities, likelihoods, evidence)best_disease = np.argmax(posterior_probabilities)return best_disease# Example usage
prior_probabilities = [0.1, 0.2, 0.3, 0.4]  # Assuming 4 diseases including health
likelihoods = [0.5, 0.3, 0.1, 0.1]  # Likelihoods of features given each disease
features = [1, 2, 3, 4]  # Example featuresdisease = diagnose_disease(features, prior_probabilities, likelihoods)
print(f"Diagnosed disease: {disease}")

8. 测试和验证

  在测试和验证基于历史数据集的CAD(Computer-Aided Diagnosis)程序的准确性时,可以按照以下步骤进行:

数据集准备:

  • 收集包含患者体征、症状和确诊疾病信息的历史数据集。确保数据集的质量和完整性,包括特征的准确性和标记的正确性。
  • 将数据集分为训练集和测试集,通常采用交叉验证或留出法来划分数据,确保模型在未见过的数据上进行测试。

模型训练:

  • 使用训练集数据来训练CAD程序的模型。这包括特征提取、计算后验概率和选择最可能的疾病等步骤。
  • 调整模型参数,例如调整特征选择方法、调整先验概率的设定等,以优化模型的性能和准确性。

模型测试和验证:

  • 使用测试集数据来评估CAD程序的准确性和性能。通过将模型应用于测试集数据,可以评估模型在未见过的数据上的表现。
  • 计算模型的准确率、召回率、F1分数等指标,评估模型的分类性能。
  • 分析模型在不同疾病类别上的表现,查看是否有误诊或漏诊的情况。

性能优化:

  • 根据测试结果和验证反馈,对模型进行调整和优化。可以尝试不同的特征组合、调整模型参数、增加训练数据量等方式来提高模型的性能。
  • 迭代性地测试、验证和优化模型,直到达到满意的准确性和性能水平。

  通过以上步骤,可以对CAD程序进行全面的测试和验证,确保其在实际应用中具有较高的准确性和可靠性。不断优化模型参数和性能,可以提高CAD程序在疾病诊断中的准确性和实用性。

9. 部署和维护

  在部署和维护CAD程序到医疗环境中,并定期更新数据和模型以适应新的医疗知识和数据时,可以采取以下步骤:

部署CAD程序:

  • 在部署CAD程序之前,确保程序已经通过了充分的测试和验证,具有较高的准确性和可靠性。
  • 部署CAD程序到医疗环境中,确保程序能够与医疗信息系统进行集成,方便医生和专业人士使用。
  • 提供培训和支持,确保医疗人员能够正确使用CAD程序进行疾病诊断。

定期更新数据和模型:

  • 收集和整理最新的医疗数据,包括患者体征、症状和确诊疾病信息。确保数据的质量和完整性。
  • 定期更新CAD程序的模型,可以通过重新训练模型或增量学习的方式来适应新的医疗知识和数据。
  • 考虑使用自动化的数据更新和模型更新流程,确保CAD程序始终基于最新的数据和知识进行疾病诊断。

监控和维护:

  • 定期监控CAD程序的性能和准确性,及时发现和解决可能出现的问题。
  • 处理患者反馈和医疗人员的建议,不断改进CAD程序的用户体验和功能。
  • 确保CAD程序的安全性和隐私保护,遵守相关的医疗法规和标准。

持续优化:

  • 根据实际应用中的反馈和需求,持续优化CAD程序的功能和性能,提高其在疾病诊断中的应用效果。
  • 参与医疗专业人士的讨论和合作,不断改进CAD程序的算法和模型,以满足医疗领域的需求。

  通过以上步骤,可以有效地部署和维护CAD程序,并定期更新数据和模型以适应新的医疗知识和数据。持续的优化和改进可以提高CAD程序在医疗环境中的应用效果和价值。

四、总结

  在疾病诊断领域,贝叶斯决策和CAD程序的应用为医疗诊断提供了新的可能性。通过提取患者的体征和症状数据,计算后验概率,并选择具有最高后验概率的疾病类别作为诊断结果,我们可以实现基于数据驱动的疾病诊断方法。在实际应用中,通过测试、验证、部署和维护CAD程序,并定期更新数据和模型,可以确保CAD程序在医疗环境中的准确性和可靠性。持续优化和改进CAD程序,与医疗专业人士合作,不断提高诊断准确性和应用效果,将为医疗诊断带来更多的机会和挑战。通过结合先进的技术和医疗知识,我们可以更好地利用数据科学的力量,为患者提供更准确、快速和个性化的疾病诊断服务。


  码文不易,本篇文章就介绍到这里,如果想要学习更多Java系列知识点击关注博主,博主带你零基础学习Java知识。与此同时,对于日常生活有困扰的朋友,欢迎阅读我的第四栏目:《国学周更—心性养成之路》,学习技术的同时,我们也注重了心性的养成。

在这里插入图片描述

相关文章:

基于贝叶斯决策的 CAD 程序设计方案

✅作者简介:2022年博客新星 第八。热爱国学的Java后端开发者,修心和技术同步精进。 🍎个人主页:Java Fans的博客 🍊个人信条:不迁怒,不贰过。小知识,大智慧。 💞当前专栏…...

算法: 二分查找题目练习

文章目录 二分查找二分查找在排序数组中查找元素的第一个和最后一个位置搜索插入位置x 的平方根山脉数组的峰顶索引寻找峰值寻找旋转排序数组中的最小值点名 总结模版 二分查找 二分查找 没啥可说的,轻轻松松~ class Solution {public int search(int[] nums, int target) {i…...

Qt开发技巧(十三)QList插入操作,扩展类型的使用,关于QSS的坑,Qt的延时方法,Qt编译的三种版本,环境搭建多练练,指向Qt源码的报错

继续讲一些Qt开发中的技巧操作: 1.QList插入操作 关于QList队列的处理中,我们最常用的就是调用append函数添加item,往前插入item很多人第一印象就是调用insert(0,xxx)来插入,其实QList完全提供了往前追加item的函数prepend()、pus…...

docker快速上手

一个轻量的虚拟机,让程序员不再纠结于环境部署,更多集中于代码编写,基础建设,开发 作用: 打包:把你软件运行所需的所有东西打包到一起 分发:把你打包好的“安装包”上传到一个镜像仓库&#…...

JAVA学习-练习试用Java实现“反转链表 II”

问题&#xff1a; 给定单链表的头指针 head 和两个整数 left 和 right &#xff0c;其中 left < right 。请你反转从位置 left 到位置 right 的链表节点&#xff0c;返回 反转后的链表 。 示例 1&#xff1a; 输入&#xff1a;head [1,2,3,4,5], left 2, right 4 输出…...

15分钟学 Python 第35天 :Python 爬虫入门(一)

Day 35 : Python 爬虫简介 1.1 什么是爬虫&#xff1f; 网页爬虫&#xff08;Web Crawler&#xff09;是自动访问互联网并提取所需信息的程序。爬虫的主要功能是模拟用户通过浏览器访问网页的操作&#xff0c;从而实现对网页内容的批量访问与信息提取。它们广泛应用于数据收集…...

【Qt】Qt学习笔记(一):Qt界面初识

Qt 是一个跨平台应用程序和 UI 开发框架。使用 Qt 您只需一次性开发应用程序&#xff0c;无须重新编写源代码&#xff0c;便可跨不同桌面和嵌入式操作系统部署这些应用程序。Qt Creator是跨平台的Qt集成开发环境。 创建项目 Qt的一些界面&#xff0c;初学时一般选择Qt Widgets …...

Unity3D游戏的内存控制详解

前言 Unity3D是一款流行的游戏引擎&#xff0c;支持多种平台&#xff0c;包括PC、移动设备和VR等。随着游戏的复杂性不断提高&#xff0c;Unity3D的内存管理变得尤为重要。本文将详细介绍Unity3D游戏中的内存控制技术&#xff0c;包括自动内存管理、对象池、延迟加载资源和手动…...

《数据结构》--栈【概念应用、图文并茂】

本节讲完栈下次再讲一下队列&#xff0c;最后补充一个串&#xff0c;我们的线性结构基本就完事了。下图中黄色框框圈中的是我们今日份内容(分为两篇博客)&#xff1a; 知识体系图 栈(Stack-LIFO)结构 栈的基础概念 栈(Stack)是一个后进先出(Last-In-First-Out)的一个特殊数据…...

国外电商系统开发-运维系统文件下载

文件下载&#xff0c;作者设计的比较先进&#xff0c;如果下载顺利&#xff0c;真的还需要点两次鼠标&#xff0c;所有的远程文件就自动的下载到了您的PC电脑上了。 现在&#xff0c;请您首选选择要在哪些服务器上下载文件&#xff1a; 选择好了服务器以后&#xff0c;现在选择…...

【CSS in Depth 2 精译_045】7.1 CSS 响应式设计中的移动端优先设计原则(上)

当前内容所在位置&#xff08;可进入专栏查看其他译好的章节内容&#xff09; 第一章 层叠、优先级与继承&#xff08;已完结&#xff09; 1.1 层叠1.2 继承1.3 特殊值1.4 简写属性1.5 CSS 渐进式增强技术1.6 本章小结 第二章 相对单位&#xff08;已完结&#xff09; 2.1 相对…...

在线教育新篇章:SpringBoot系统开发策略

2相关技术 2.1 MYSQL数据库 MySQL是一个真正的多用户、多线程SQL数据库服务器。 是基于SQL的客户/服务器模式的关系数据库管理系统&#xff0c;它的有点有有功能强大、使用简单、管理方便、安全可靠性高、运行速度快、多线程、跨平台性、完全网络化、稳定性等&#xff0c;非常…...

cmdsh

#!/bin/bash #set -x bindirname "$0" bincd "$bin"; pwd echo $bin if [ $# -lt 2 ] then echo “Usage: ./runRemoteCmd.sh Command MachineTag” echo “Usage: ./runRemoteCmd.sh Command MachineTag confFile” exit fi cmd$1 tag$2 if [ a’ 3 ′…...

一键生成PPT的AI工具-Kimi!

一键生成PPT的AI工具-Kimi&#xff01; 前言介绍Kimi为什么选择Kimi如何使用Kimi在线编辑PPT下载生成的PPT自己编辑 结语 &#x1f600;大家好&#xff01;我是向阳&#x1f31e;&#xff0c;一个想成为优秀全栈开发工程师的有志青年&#xff01; &#x1f4d4;今天不来讨论前后…...

java.lang.NoClassDefFoundError: kotlin/Result解决方案

问题 在控制窗口上虽然报错是找不到对应的class&#xff0c;但是呢在我们导入kotlin的后&#xff0c;还是报相同的异常&#xff0c;在网上查找了各种资料&#xff0c;都没有解决方案。 问题分析 在idea2021之后&#xff0c;kotlin都使用远程仓库&#xff08;kotlinx-coeouti…...

LSTM的变体

一、GRU 1、什么是GRU 门控循环单元&#xff08;GRU&#xff09;是一种循环神经网络&#xff08;RNN&#xff09;的变体&#xff0c;它通过引入门控机制来控制信息的流动&#xff0c;从而有效地解决了传统RNN中的梯度消失问题。GRU由Cho等人在2014年提出&#xff0c;它简化了…...

LeetCode讲解篇之852. 山脉数组的峰顶索引

文章目录 题目描述题解思路题解代码题目链接 题目描述 题解思路 我们可以采用二分查找&#xff0c;每次查询区间中点元素与中点下一个元素比较 如果中点元素大于其下一个元素&#xff0c;则表示从中点开始向右是递减趋势&#xff0c;那峰值索引一定小于等于中点&#xff0c;我…...

矿井人员数据集,用于目标检测,深度学习,采用txt打标签,即yolo格式,也有原文件可以自己转换。总共3500张图片的数据量,划分给训练集2446张,

矿井人员数据集&#xff0c;用于目标检测&#xff0c;深度学习&#xff0c;采用txt打标签&#xff0c;即yolo格式&#xff0c;也有原文件可以自己转换。总共3500张图片的数据量&#xff0c;划分给训练集2446张&#xff1a; ### 矿井人员数据集用于目标检测的详细说明 #### 1. …...

消息队列RabbitMQ

文章目录 1. 简介与安装2. 基本概念3. SpringAMQP4. 交换机类型5. 消息转换器5.1 默认转换器5.2 配置JSON转换器 6 生产者的可靠性6.1 生产者超时重连机制6.2 生产者确认机制 6. MQ的可靠性6.1 数据持久化6.2 惰性队列 Lazy Queue 7. 消费者的可靠性7.1 消费者确认机制7.2 失败…...

RabbitMQ概述

什么是MQ MQ (message queue)消息队列 MQ从字⾯意思上看,本质是个队列,FIFO先⼊先出&#xff0c;只不过队列中存放的内容是消息(message).消息可以⾮常简单,⽐如只包含⽂本字符串,JSON等,也可以很复杂,⽐如内嵌对象 RabbitMQ是MQ的一种实现,是Rabbit 企业下的⼀个消息队列产…...

Qt/C++开发监控GB28181系统/取流协议/同时支持udp/tcp被动/tcp主动

一、前言说明 在2011版本的gb28181协议中&#xff0c;拉取视频流只要求udp方式&#xff0c;从2016开始要求新增支持tcp被动和tcp主动两种方式&#xff0c;udp理论上会丢包的&#xff0c;所以实际使用过程可能会出现画面花屏的情况&#xff0c;而tcp肯定不丢包&#xff0c;起码…...

相机Camera日志实例分析之二:相机Camx【专业模式开启直方图拍照】单帧流程日志详解

【关注我&#xff0c;后续持续新增专题博文&#xff0c;谢谢&#xff01;&#xff01;&#xff01;】 上一篇我们讲了&#xff1a; 这一篇我们开始讲&#xff1a; 目录 一、场景操作步骤 二、日志基础关键字分级如下 三、场景日志如下&#xff1a; 一、场景操作步骤 操作步…...

从零开始打造 OpenSTLinux 6.6 Yocto 系统(基于STM32CubeMX)(九)

设备树移植 和uboot设备树修改的内容同步到kernel将设备树stm32mp157d-stm32mp157daa1-mx.dts复制到内核源码目录下 源码修改及编译 修改arch/arm/boot/dts/st/Makefile&#xff0c;新增设备树编译 stm32mp157f-ev1-m4-examples.dtb \stm32mp157d-stm32mp157daa1-mx.dtb修改…...

vue3 定时器-定义全局方法 vue+ts

1.创建ts文件 路径&#xff1a;src/utils/timer.ts 完整代码&#xff1a; import { onUnmounted } from vuetype TimerCallback (...args: any[]) > voidexport function useGlobalTimer() {const timers: Map<number, NodeJS.Timeout> new Map()// 创建定时器con…...

LINUX 69 FTP 客服管理系统 man 5 /etc/vsftpd/vsftpd.conf

FTP 客服管理系统 实现kefu123登录&#xff0c;不允许匿名访问&#xff0c;kefu只能访问/data/kefu目录&#xff0c;不能查看其他目录 创建账号密码 useradd kefu echo 123|passwd -stdin kefu [rootcode caozx26420]# echo 123|passwd --stdin kefu 更改用户 kefu 的密码…...

音视频——I2S 协议详解

I2S 协议详解 I2S (Inter-IC Sound) 协议是一种串行总线协议&#xff0c;专门用于在数字音频设备之间传输数字音频数据。它由飞利浦&#xff08;Philips&#xff09;公司开发&#xff0c;以其简单、高效和广泛的兼容性而闻名。 1. 信号线 I2S 协议通常使用三根或四根信号线&a…...

Netty从入门到进阶(二)

二、Netty入门 1. 概述 1.1 Netty是什么 Netty is an asynchronous event-driven network application framework for rapid development of maintainable high performance protocol servers & clients. Netty是一个异步的、基于事件驱动的网络应用框架&#xff0c;用于…...

【SSH疑难排查】轻松解决新版OpenSSH连接旧服务器的“no matching...“系列算法协商失败问题

【SSH疑难排查】轻松解决新版OpenSSH连接旧服务器的"no matching..."系列算法协商失败问题 摘要&#xff1a; 近期&#xff0c;在使用较新版本的OpenSSH客户端连接老旧SSH服务器时&#xff0c;会遇到 "no matching key exchange method found"​, "n…...

三分算法与DeepSeek辅助证明是单峰函数

前置 单峰函数有唯一的最大值&#xff0c;最大值左侧的数值严格单调递增&#xff0c;最大值右侧的数值严格单调递减。 单谷函数有唯一的最小值&#xff0c;最小值左侧的数值严格单调递减&#xff0c;最小值右侧的数值严格单调递增。 三分的本质 三分和二分一样都是通过不断缩…...

django blank 与 null的区别

1.blank blank控制表单验证时是否允许字段为空 2.null null控制数据库层面是否为空 但是&#xff0c;要注意以下几点&#xff1a; Django的表单验证与null无关&#xff1a;null参数控制的是数据库层面字段是否可以为NULL&#xff0c;而blank参数控制的是Django表单验证时字…...