温控系统c语言源代码,模糊PID控制温控系统设计C语言程序代码

时间: 2023-11-26 22:06:07 浏览: 45
以下是一个基于模糊PID控制的温控系统的C语言源代码示例: ``` #include <stdio.h> #include <stdlib.h> #include <math.h> #define TEMP_SET_POINT 60.0 // 温度设定值 #define TEMP_TOLERANCE 2.0 // 温度容差 #define MAX_POWER 100.0 // 最大加热功率 #define MIN_POWER 0.0 // 最小加热功率 #define SAMPLE_TIME 0.1 // 采样时间 // 模糊控制参数 #define NB 7 // 模糊集合数量 #define NM 7 #define NS 7 #define ZE 7 #define PS 7 #define PM 7 #define PB 7 #define DE 0.1 // 均匀分割间隔 #define e_c PS // e_c: e的上限 #define e_s NS // e的下限 #define delta_u_c PM // delta_u的上限 #define delta_u_s NM // delta_u的下限 // 模糊集合隶属度函数 double NB_func(double e) { return 1.0 / (1.0 + exp(-NB * (e - PB))); } double NM_func(double e) { return 1.0 / (1.0 + exp(-NM * (e - PM))); } double NS_func(double e) { return 1.0 / (1.0 + exp(-NS * (e - ZE))); } double ZE_func(double e) { return 1.0 / (1.0 + exp(-ZE * (e - ZE))); } double PS_func(double e) { return 1.0 / (1.0 + exp(-PS * (e - ZE))); } double PM_func(double e) { return 1.0 / (1.0 + exp(-PM * (e - NM))); } double PB_func(double e) { return 1.0 / (1.0 + exp(-PB * (e - NB))); } // 模糊控制规则库 double delta_u_table[7][7] = { {PB, PM, PM, ZE, NS, NS, NS}, {PB, PM, PM, NS, NS, NS, NS}, {PM, PM, ZE, NS, NS, NS, NM}, {PM, PS, ZE, NS, NS, NM, NM}, {PS, ZE, NS, NS, NM, NM, NB}, {ZE, ZE, NS, NM, NM, NB, NB}, {ZE, PS, PM, NM, NB, NB, NB} }; // 模糊控制 double fuzzy_control(double e, double delta_e) { double delta_u = 0.0; int i, j; double e_array[7], delta_e_array[7]; double u_array[7] = {MIN_POWER, MIN_POWER, MIN_POWER, MIN_POWER, MIN_POWER, MIN_POWER, MIN_POWER}; double sum_e = 0.0, sum_delta_e = 0.0, sum_u = 0.0, sum_w = 0.0, w = 0.0; // 计算e、delta_e的隶属度 e_array[0] = NB_func(e); e_array[1] = NM_func(e); e_array[2] = NS_func(e); e_array[3] = ZE_func(e); e_array[4] = PS_func(e); e_array[5] = PM_func(e); e_array[6] = PB_func(e); delta_e_array[0] = NB_func(delta_e); delta_e_array[1] = NM_func(delta_e); delta_e_array[2] = NS_func(delta_e); delta_e_array[3] = ZE_func(delta_e); delta_e_array[4] = PS_func(delta_e); delta_e_array[5] = PM_func(delta_e); delta_e_array[6] = PB_func(delta_e); // 计算u的隶属度 for (i = 0; i < 7; i++) { for (j = 0; j < 7; j++) { w = e_array[i] * delta_e_array[j]; u_array[(int)round(delta_u_table[i][j])] = fmax(u_array[(int)round(delta_u_table[i][j])], w); } } // 计算delta_u for (i = 0; i < 7; i++) { delta_u += u_array[i] * (i * DE + delta_u_s); sum_w += u_array[i]; } delta_u /= sum_w; return delta_u; } int main() { double temp = 20.0; // 初始温度为20度 double last_temp = 20.0; // 上次温度 double e = 0.0, delta_e = 0.0; double power = 0.0; double time = 0.0; double Kp = 0.2, Ki = 0.1, Kd = 0.05; // PID控制参数 double last_error = 0.0, error = 0.0, error_integral = 0.0, error_derivative = 0.0; while (fabs(temp - TEMP_SET_POINT) > TEMP_TOLERANCE) { // 计算误差和误差变化率 last_error = error; error = TEMP_SET_POINT - temp; error_integral += error * SAMPLE_TIME; error_derivative = (error - last_error) / SAMPLE_TIME; // 计算模糊PID控制输出 delta_e = Kp * error + Ki * error_integral + Kd * error_derivative; power = fuzzy_control(error, delta_e); // 限制输出范围 power = fmin(power, MAX_POWER); power = fmax(power, MIN_POWER); // 模拟温度变化 temp += power / 10.0 * SAMPLE_TIME; // 输出结果 printf("Time: %.1f s, Temperature: %.1f C, Power: %.1f %%\n", time, temp, power); // 更新时间 time += SAMPLE_TIME; } printf("Temperature control finished.\n"); return 0; } ``` 这个代码示例中,模糊PID控制使用了7个模糊集合,每个模糊集合都有一个隶属度函数,模糊控制规则库使用了一个7x7的表格,其中每个元素表示 delta_u(控制量)的隶属度,表格中的行和列分别代表误差e和误差变化率delta_e的模糊集合。在模糊控制中,通过计算e和delta_e的隶属度以及控制量的隶属度,可以得到一个delta_u的模糊值,最终通过求加权平均值得到delta_u的模糊输出,然后根据模糊输出和PID控制算法计算出实际控制量,并对其进行限制输出范围。

相关推荐

最新推荐

recommend-type

基于AT89S51单片机的PID温度控制系统设计

本文对系统进行硬件和软件的设计,在建立温度控制系统数学模型的基础之上,通过对PID控制的分析设计了系统控制器,完成了系统的软、硬件调试工作。算法简单、可靠性高、鲁棒性好,而且PID控制器参数直接影响控制效果...
recommend-type

基于STM32的温度控制系统设计.pdf

基于STM32系统的温度控制系统设计,此资源包括设计报告及相关电路。 温度监控主要应用在温室以及需要对温度进行监控的地方,主要目的是为了能够感知所检测区域的温度情况并进行温度控制。设计以 STM32F103 作为系统...
recommend-type

基于PID算法和89C52单片机的温度控制系统

单片机作为控制系统中必不可少的部分,在各个领域得到了广泛的应用,用单片机进行实时系统数据处理和控制,保证系统工作在最佳状态,提高系统的控制精度,有利于提高...本系统采用单片机编程实现PID算法进行温度控制。
recommend-type

一种基于单片机的水位自动控制系统设计

本文介绍了水位自动控制系统工作的基本原理。阐述了一种基于单片机的通用水位控制系统的基本组成,并提出了该系统模块化的硬件和软件设计方法,最后,对该系统的工程应用作了评价和讨论。
recommend-type

基于DS18B20测温的单片机温度控制系统

温度是工业控制中主要的被控参数之一.对典型的温度控制系统进行研究具有很广泛的意义。
recommend-type

RTL8188FU-Linux-v5.7.4.2-36687.20200602.tar(20765).gz

REALTEK 8188FTV 8188eus 8188etv linux驱动程序稳定版本, 支持AP,STA 以及AP+STA 共存模式。 稳定支持linux4.0以上内核。
recommend-type

管理建模和仿真的文件

管理Boualem Benatallah引用此版本:布阿利姆·贝纳塔拉。管理建模和仿真。约瑟夫-傅立叶大学-格勒诺布尔第一大学,1996年。法语。NNT:电话:00345357HAL ID:电话:00345357https://theses.hal.science/tel-003453572008年12月9日提交HAL是一个多学科的开放存取档案馆,用于存放和传播科学研究论文,无论它们是否被公开。论文可以来自法国或国外的教学和研究机构,也可以来自公共或私人研究中心。L’archive ouverte pluridisciplinaire
recommend-type

:YOLO目标检测算法的挑战与机遇:数据质量、计算资源与算法优化,探索未来发展方向

![:YOLO目标检测算法的挑战与机遇:数据质量、计算资源与算法优化,探索未来发展方向](https://img-blog.csdnimg.cn/7e3d12895feb4651b9748135c91e0f1a.png?x-oss-process=image/watermark,type_ZHJvaWRzYW5zZmFsbGJhY2s,shadow_50,text_Q1NETiBA5rKJ6YaJ77yM5LqO6aOO5Lit,size_20,color_FFFFFF,t_70,g_se,x_16) # 1. YOLO目标检测算法简介 YOLO(You Only Look Once)是一种
recommend-type

def ObjFun(x,y,beta): # 目标函数 """ Logistic regression loss function :param beta: model parameter vector :param x: feature matrix :param y: label vector :return: loss value """ n = x.shape[0] p = x.shape[1] pred = 1 / (1 + np.exp(-np.dot(x, beta))) pred = np.clip(pred, 1e-15, 1 - 1e-15) # 将预测值限制在一个很小的区间内 ObjVal = -np.sum(y * np.log(pred) + (1 - y) * np.log(1 - pred)) / n return ObjVal

好的,根据上面的目标函数,我们可以推导出其对应的梯度向量函数,如下所示: def gradient(x, y, beta): """ Compute gradient of the logistic regression loss function :param beta: model parameter vector :param x: feature matrix :param y: label vector :return: gradient vector """ n = x.shape[0] pred = 1 /
recommend-type

c++校园超市商品信息管理系统课程设计说明书(含源代码) (2).pdf

校园超市商品信息管理系统课程设计旨在帮助学生深入理解程序设计的基础知识,同时锻炼他们的实际操作能力。通过设计和实现一个校园超市商品信息管理系统,学生掌握了如何利用计算机科学与技术知识解决实际问题的能力。在课程设计过程中,学生需要对超市商品和销售员的关系进行有效管理,使系统功能更全面、实用,从而提高用户体验和便利性。 学生在课程设计过程中展现了积极的学习态度和纪律,没有缺勤情况,演示过程流畅且作品具有很强的使用价值。设计报告完整详细,展现了对问题的深入思考和解决能力。在答辩环节中,学生能够自信地回答问题,展示出扎实的专业知识和逻辑思维能力。教师对学生的表现予以肯定,认为学生在课程设计中表现出色,值得称赞。 整个课程设计过程包括平时成绩、报告成绩和演示与答辩成绩三个部分,其中平时表现占比20%,报告成绩占比40%,演示与答辩成绩占比40%。通过这三个部分的综合评定,最终为学生总成绩提供参考。总评分以百分制计算,全面评估学生在课程设计中的各项表现,最终为学生提供综合评价和反馈意见。 通过校园超市商品信息管理系统课程设计,学生不仅提升了对程序设计基础知识的理解与应用能力,同时也增强了团队协作和沟通能力。这一过程旨在培养学生综合运用技术解决问题的能力,为其未来的专业发展打下坚实基础。学生在进行校园超市商品信息管理系统课程设计过程中,不仅获得了理论知识的提升,同时也锻炼了实践能力和创新思维,为其未来的职业发展奠定了坚实基础。 校园超市商品信息管理系统课程设计的目的在于促进学生对程序设计基础知识的深入理解与掌握,同时培养学生解决实际问题的能力。通过对系统功能和用户需求的全面考量,学生设计了一个实用、高效的校园超市商品信息管理系统,为用户提供了更便捷、更高效的管理和使用体验。 综上所述,校园超市商品信息管理系统课程设计是一项旨在提升学生综合能力和实践技能的重要教学活动。通过此次设计,学生不仅深化了对程序设计基础知识的理解,还培养了解决实际问题的能力和团队合作精神。这一过程将为学生未来的专业发展提供坚实基础,使其在实际工作中能够胜任更多挑战。