Python:熟悉简单的skfuzzy构建接近生活事件的模糊控制器”(附带详细注释说明)+ 测试结果

news2024/9/29 23:27:18
参考资料:https: // blog.csdn.net / shelgi / article / details / 126908418
————通过下面这个例子,终于能理解一点模糊理论的应用了,感谢原作。
熟悉简单的skfuzzy构建接近生活事件的模糊控制器
假设下面这样的场景, 我们希望构建一套模糊控制系统, 通过室外温度和风的大小来判断穿几件衣服
室外温度的范围设置为0 - 40度, 虽然今年夏天超过40度在我们这边很平常, 但是我们这里还是以40度为最高界限
风的大小范围0 - 10, 这里不是风的级数, 而是我自己构建的大小.模糊理论奥妙就在于不需要精确的逻辑值,
可以模糊描述.比如小风我设置为1 - 3, 然后有点大的风等等, 都是比较抽象的描述, 但是经过隶属函数可以看出, 往往某个值是在多个状态叠加.
衣服的件数我设置为1 - 6(不能一件衣服不穿), 如果按照本人自己的爱好, 我最多也只穿三件.不过考虑到实际还是设一个大点的范围

常见模糊隶属度函数


import matplotlib.pyplot as plt
import numpy as np
import skfuzzy as fuzz
from skfuzzy import control as ctrl
import matplotlib.pyplot as plt

"""
    scikit-fuzzy模块,它可以实现模糊控制系统
    1.选择输入输出模糊集
    2.定义输入输出隶属度函数(不同的隶属度函数,会导致不同的控制特性)
    3.建立模糊控制表
    4.建立模糊控制规则
    5.模糊推理
    6.反模糊化
    7.输出结果绘制结果3D图
"""

""" 方式一: 调用库函数 """
if 0:
    temp = ctrl.Antecedent(np.arange(0, 41, 1), 'temp')
    wind = ctrl.Antecedent(np.arange(0, 11, 1), 'wind')
    clothes = ctrl.Consequent(np.arange(1, 7, 1), 'clothes')

    # 自动找成员函数,分为三类
    temp.automf(3)
    wind.automf(3)

    # 设置目标的模糊规则
    clothes['low'] = fuzz.trimf(clothes.universe, [1, 1, 3])
    clothes['medium'] = fuzz.trimf(clothes.universe, [1, 3, 6])
    clothes['high'] = fuzz.trimf(clothes.universe, [3, 6, 6])

    rule1 = ctrl.Rule(temp['good'] | wind['poor'], clothes['low'])
    rule2 = ctrl.Rule(temp['average'], clothes['medium'])
    rule3 = ctrl.Rule(temp['poor'] | wind['good'], clothes['high'])

    rule1.view()
    rule2.view()
    rule3.view()

    # 创建控制系统,应用编写好的规则
    cloth_ctrl = ctrl.ControlSystem([rule1, rule2, rule3])

    # 创建控制仿真器
    cloth_num = ctrl.ControlSystemSimulation(cloth_ctrl)

    # 输入测试数据
    cloth_num.input['temp'] = 20
    cloth_num.input['wind'] = 2

    # 设置去模糊方法
    clothes.defuzzify_method = 'mom'

    # 计算结果
    cloth_num.compute()

    cloth_num_res = cloth_num.output['clothes']
    print(f"The result of clothes: {cloth_num_res}")

    # 可视化
    clothes.view(sim=cloth_num)

    plt.show()

else:
    """ 方式二: 手动实现模糊规则 """
    plt.rcParams['font.family'] = 'simhei'
    x_temp = np.arange(0, 41, 1)
    x_wind = np.arange(0, 11, 1)
    x_clothes = np.arange(1, 7, 1)

    # 将三角隶属度函数对各个量进行隶属度映射
    temp_cold = fuzz.trimf(x_temp, [0, 0, 15])
    temp_warm = fuzz.trimf(x_temp, [5, 25, 35])
    temp_hot = fuzz.trimf(x_temp, [25, 40, 40])

    plt.figure()
    plt.title("Temperature")
    plt.plot(x_temp, temp_cold, 'b', label='cold')
    plt.plot(x_temp, temp_warm, 'y', label='warm')
    plt.plot(x_temp, temp_hot, 'r', label='hot')
    plt.legend()
    # plt.show()

    wind_low = fuzz.trimf(x_wind, [0, 0, 5])
    wind_medium = fuzz.trimf(x_wind, [0, 5, 10])
    wind_high = fuzz.trimf(x_wind, [5, 10, 10])

    plt.figure()
    plt.title("Wind")
    plt.plot(x_wind, wind_low, 'b', label='low')
    plt.plot(x_wind, wind_medium, 'y', label='medium')
    plt.plot(x_wind, wind_high, 'r', label='high')
    plt.legend()
    # plt.show()

    cloth_low = fuzz.trimf(x_clothes, [1, 1, 3])
    cloth_medium = fuzz.trimf(x_clothes, [1, 3, 6])
    cloth_high = fuzz.trimf(x_clothes, [3, 6, 6])

    plt.figure()
    plt.title("clothes")
    plt.plot(x_clothes, cloth_low, 'b', label='low')
    plt.plot(x_clothes, cloth_medium, 'y', label='medium')
    plt.plot(x_clothes, cloth_high, 'r', label='high')
    plt.legend()
    # plt.show()

    temp_test = 30
    wind_test = 5

    temp_level_cold = fuzz.interp_membership(x_temp, temp_cold, temp_test)
    temp_level_warm = fuzz.interp_membership(x_temp, temp_warm, temp_test)
    temp_level_hot = fuzz.interp_membership(x_temp, temp_hot, temp_test)

    wind_level_low = fuzz.interp_membership(x_wind, wind_low, wind_test)
    wind_level_medium = fuzz.interp_membership(x_wind, wind_medium, wind_test)
    wind_level_high = fuzz.interp_membership(x_wind, wind_high, wind_test)

    # 模糊规则
    # 当风小或者温度高的时候我们穿很少的衣服
    # 当温度中等, 比较温暖的时候我们穿得稍微多点
    # 当温度很低或者风很大的时候, 那我们就需要穿很多衣服了
    rule1 = np.fmax(temp_level_hot, wind_level_low)
    cloth_res_low = np.fmin(rule1, cloth_low)

    cloth_res_medium = np.fmin(temp_level_warm, cloth_medium)

    rule2 = np.fmax(temp_level_cold, wind_level_high)
    cloth_res_high = np.fmin(rule2, cloth_high)

    clothes = np.zeros_like(x_clothes)

    # vis
    plt.figure(figsize=(8, 3))
    plt.title("结果")
    plt.plot(x_clothes, cloth_low, 'b')
    plt.fill_between(x_clothes, 0, cloth_res_low)
    plt.plot(x_clothes, cloth_medium, 'g')
    plt.fill_between(x_clothes, 0, cloth_res_medium)
    plt.plot(x_clothes, cloth_high, 'r')
    plt.fill_between(x_clothes, 0, cloth_res_high)
    # plt.show()

    # 去模糊
    aggregated = np.fmax(cloth_res_low, np.fmax(cloth_res_medium, cloth_res_high))

    # 去模糊方法:
    # 反模糊化方法有很多
    # centroid面积重心法
    # bisector面积等分法
    # mom最大隶属度平均法
    # som最大隶属度取最小法
    # lom最大隶属度取最大法
    cloth = fuzz.defuzz(x_clothes, aggregated, 'mom')

    cloth_res = fuzz.interp_membership(x_clothes, aggregated, cloth)

    plt.figure(figsize=(8, 3))
    plt.title(f"去模糊化结果cloth:{cloth}")
    plt.plot(x_clothes, cloth_low, 'b')
    plt.plot(x_clothes, cloth_medium, 'g')
    plt.plot(x_clothes, cloth_high, 'r')
    plt.fill_between(x_clothes, 0, aggregated, facecolor='orange')
    plt.plot([cloth, cloth], [0, cloth_res], 'k')
    plt.show()

  1. 测试温度:temp_test = 30;测试风速:wind_test = 5
    在这里插入图片描述
  1. 测试温度:temp_test = 10;测试风速:wind_test = 8
    在这里插入图片描述
  1. 测试温度:temp_test = 40;测试风速:wind_test = 2
    在这里插入图片描述

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

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

相关文章

linux系统------------MySQL 存储引擎

目录 一、存储引擎概念介绍 二、常用的存储引擎 2.1MyISAM 2.1.1MYlSAM的特点 2.1.2MyISAM 表支持 3 种不同的存储格式⭐: (1)静态(固定长度)表 (2)动态表 (3)压缩表 2.1.3MyISAM适…

基于python+vue食品安全信息管理系统flask-django-nodejs-php

食品安全信息管理系统设计的目的是为用户提供食品信息、科普专栏、食品检测、检测结果、交流论坛等方面的平台。 与PC端应用程序相比,食品安全信息管理系统的设计主要面向于用户,旨在为管理员和用户提供一个食品安全信息管理系统。用户可以通过APP及时查…

Gitlab介绍

1.什么是Gitlab GitLab是一个流行的版本控制系统平台,主要用于代码托管、测试和部署。 GitLab是基于Git的一个开源项目,它提供了一个用于仓库管理的Web服务。GitLab使用Ruby on Rails构建,并提供了诸如wiki和issue跟踪等功能。它允许用户通…

欧科云链:2024将聚焦发展与安全,用技术助力链上数据安全和合规

近期,OpenAI和Web3.0两大新技术发展势头迅猛。OpenAI 再次引领AI领域的新浪潮,推出了创新的文本转视频模型——Sora,Sora 可以创建长达60 秒的视频,包含高度详细的场景、複杂的摄像机运动以及情感丰富角色,再次将AI 的…

Django在日志中使用AdminEmailHandler发送邮件(同步),及celery异步发送日志邮件的实现

目录 一、使用AdminEmailHandler实现发送日志通知邮件 1,配置日志项 2,配置邮件项 3,在视图里使用日志 二、继承AdminEmailHandler使用celery实现异步发送邮件 1,安装配置celery 2,继承AdminEmailHandler类&…

python食品安全信息管理系统flask-django-nodejs-php

。 食品安全信息管理系统是在安卓操作系统下的应用平台。为防止出现兼容性及稳定性问题,编辑器选择的是Hbuildex,安卓APP与后台服务端之间的数据存储主要通过MySQL。用户在使用应用时产生的数据通过 python等语言传递给数据库。通过此方式促进食品安全信…

VMware 15 中 Ubuntu与windows 10共享文件夹设置

wmware 15.5.7中安装ubuntu 22.04 物理机为windows 10 1.选中ubuntu中想要共享的文件夹右击,点属性 2.在Local network share中勾选share this folder,第一次会提示你安装samba,安装即可 3.window10的资源管理器中使用 虚拟机计算机名即可…

无人机采集图像的相关知识

1.飞行任务规划 一般使用飞行任务规划软件进行飞行任务的设计,软件可以自动计算相机覆盖和图像重叠情况。比如ArduPilot (ArduPilot - Versatile, Trusted, Open) 和UgCS (http://www.ugcs.com)是两个飞行任务规划软件,可以适用大多数无人机系统。 2.图…

如何减少pdf的文件大小?pdf压缩工具介绍

文件发不出去,有时就会耽误工作进度,文件太大无法发送,这应该是大家在发送PDF时,常常会碰到的问题吧,那么PDF文档压缩大小怎么做呢?因此我们需要对pdf压缩后再发送,那么有没有好用的pdf压缩工具…

解决IE11报错:CSS 因 Mime 类型不匹配而被忽略

简要概述: 本人用springboot开发网站,手动处理js和css文件请求,报错:CSS 因 Mime 类型不匹配而被忽略 后台代码: 如下三个代码块 GetMapping("/Guest/ASN1/{FileName}")public void GetFiles(PathVariab…

阿里云 EMR Serverless Spark 版免费邀测中

随着大数据应用的广泛推广,企业对于数据处理的需求日益增长。为了进一步优化大数据开发流程,减少企业的运维成本,并提升数据处理的灵活性和效率,阿里云开源大数据平台 E-MapReduce (简称“EMR”)正式推出 E…

SQL中条件放在on后与where后的区别

数据库在通过连接两张或多张表来返回记录时,都会生成一张中间的临时表,然后再将这张临时表返回给用户。 在使用left jion时,on和where条件的区别如下: on条件是在生成临时表时使用的条件,不管on中的条件是否为真&…

深度学习Top10算法之深度神经网络DNN

深度神经网络(Deep Neural Networks,DNN)是人工神经网络(Artificial Neural Networks,ANN)的一种扩展。它们通过模仿人脑的工作原理来处理数据和创建模式,广泛应用于图像识别、语音识别、自然语…

Dell戴尔XPS 12 9250二合一笔记本电脑原装出厂Windows10系统包下载

链接:https://pan.baidu.com/s/1rqUEM_q5DznF0om6eevcwg?pwdvij0 提取码:vij0 戴尔原厂WIN10系统自带所有驱动、出厂主题壁纸、系统属性专属联机支持标志、系统属性专属LOGO标志、Office办公软件、MyDell等预装程序 文件格式:esd/wim/sw…

Spring Cloud Alibaba Sentinel 使用详解

一、Sentinel 介绍 随着微服务的流行,服务和服务之间的稳定性变得越来越重要。 Sentinel 以流量为切入点,从流量控制、熔断降级、系统负载保护等多个维度保护服务的稳定性。 Sentinel 具有以下特征: 丰富的应用场景: Sentinel 承接了阿里巴…

【BUG】java.nio.charset.MalformedInputException: Input length = 1

springboot maven 项目启动 编码异常 修改 ERROR org.springframework.boot.SpringApplication - Application run failed java.nio.charset.MalformedInputException: Input length 1 … 修改编码为UTF-8maven : clean -> compile

深度学习:复杂工业场景下的复杂缺陷检测方法

摘要:在复杂的工业场景中,缺陷检测一直是一个重要而具有挑战性的任务。近年来,深度学习技术的快速发展为复杂工业场景下的缺陷检测提供了新的解决方案。本文将介绍深度学习在复杂工业场景下的复杂缺陷检测中的应用,并探讨其技术进…

cool-admin-node.js 中redis缓存的使用

1. 在做cool 后端的时候 用户登录 时的token 需要鉴权的value 以及发送验证码 这些 需要存到缓存里面 ,进行逻辑鉴权 所以我们需要用到redis 缓存 或者数据库缓存 我这里介绍一下redis 的缓存 在cool-admin 中 使用的一般都是宝塔面板 首先得有服务器 需要有自己的…

如何屏蔽来自一些可疑IP对网站的访问

前段时间我们的网站遭受到黑客的攻击,导致网站出现乱码以及丢失了一些网站文件。在我们将网站全部迁移至Hostease虚拟主机后,为了再次避免这种情况发生,我们对网站做了一些安全防护,除了安装一些安全插件之外,我们还屏…

计算机组成原理 数据通路组成实验

一、实验目的 (1)将双端口通用寄存器堆和双端口存储器模块联机; (2)进一步熟悉计算机的数据通路; (3)掌握数字逻辑电路中故障的一般规律,以及排除故障的一般原则和方法; (4)锻炼分析问题与解决问题的能力,在出现故障的情况下,独立分析故障…