问小白 wenxiaobai
资讯
历史
科技
环境与自然
成长
游戏
财经
文学与艺术
美食
健康
家居
文化
情感
汽车
三农
军事
旅行
运动
教育
生活
星座命理

Proteus仿真:基于STM32的简易波形发生器设计

创作时间:
作者:
@小白创作中心

Proteus仿真:基于STM32的简易波形发生器设计

引用
CSDN
1.
https://m.blog.csdn.net/XCHardware/article/details/139872560

本文介绍了一个基于STM32单片机的简易波形发生器的Proteus仿真设计。通过按键可以调节输出波形的类型(方波、三角波、锯齿波),并在Proteus内置示波器上实时观察波形变化。文章详细介绍了系统设计和程序实现,适合电子工程和嵌入式系统开发领域的工程师和学生参考。

一.系统概述

系统内使用STM32单片机进行主控,proteus内部集成示波器,使用按键可以调节波形的输出方式,在示波器上可以实时观察波形的变化。

二.仿真概述

  1. 调出示波器且此时没有按下按键波形就是一条直线
    2.按下方波按键就可以在示波器上看到方波波形
  2. 按下三角波按键就可以在示波器上看到三角波波形
    4.按下锯齿波按键就能看到锯齿波波形,可以调节示波器的旋钮来移动查看和放大缩小

三.程序设计

#include <stm32f10x.h>
#include <delay.h>
#include <Lcd1602.h>
#include <DAC0832.h>
#include <Key.h>

int main(void)
{	
    u8 f=0,i=0,k=0;
    
    Lcd1602_Init();
    DAC0832_Init();
    Key_Init();
    
    while(1)
    {
        if(Key0==0||Key1==0||Key2==0||Key3==0)
        {
            delay_ms(100);
            if(Key0==0)
            {
                k=1;
                while(Key0);
            }
            if(Key1==0)
            {
                k=2;
                while(Key1);
            }
            if(Key2==0)
            {
                k=3;
                while(Key2);
            }
            if(Key3==0)
            {
                k=0;
                while(Key3);
            }		
        }
        
        if(k==1)
        {
            //方波======================================
            if(f==0)
            {
                i++;
                DAC_com(255);
                delay_us(19);
                if(i==255)
                {
                    f=1;
                }
            }
            else
            {
                i--;
                DAC_com(0);
                delay_us(19);
                if(i==0)
                {
                    f=0;
                }
            }
        }
        if(k==2)
        {
            //三角波======================================
            if(f==0)
            {
                i++;
                DAC_com(i);
                delay_us(19);
                if(i==255)
                {
                    f=1;
                }
            }
            else
            {
                i--;
                DAC_com(i);
                delay_us(19);
                if(i==0)
                {
                    f=0;
                }
            }
        }
        
        if(k==3)
        {
            //锯齿======================================
            if(f==0)
            {
                if(i<255)
                {
                    i++;
                    DAC_com(i);
                    delay_us(19);
                }else i=0;
            }
        }				
    }	
}
© 2023 北京元石科技有限公司 ◎ 京公网安备 11010802042949号