python蜂鸣器天空之城频率_如何把两个程序合在一起实现(小车超声波避障+蜂鸣器音乐《天空之城》)...
小车超声波程序:
......
#include
#include
#define Sevro_moto_pwm P2_7 //接舵机信号端输入PWM信号调节速度
#define ECHO P2_4 //超声波接口定义
#define TRIG P2_5 //超声波接口定义
#define Left_moto_go {P1_0=1,P1_1=0,P1_2=1,P1_3=0;} //左边两个电机向前走
#define Left_moto_back {P1_0=0,P1_1=1,P1_2=0,P1_3=1;} //左边两个电机向后转
#define Left_moto_Stop {P1_0=0,P1_1=0,P1_2=0,P1_3=0;} //左边两个电机停转
#define Right_moto_go {P1_4=1,P1_5=0,P1_6=1,P1_7=0;} //右边两个电机向前走
#define Right_moto_back {P1_4=0,P1_5=1,P1_6=0,P1_7=1;} //右边两个电机向前走
#define Right_moto_Stop {P1_4=0,P1_5=0,P1_6=0,P1_7=0;} //右边两个电机停转
unsigned char const discode[] ={ 0xC0,0xF9,0xA4,0xB0,0x99,0x92,0x82,0xF8,0x80,0x90,0xBF,0xff/*-*/};
unsigned char const positon[3]={ 0xfe,0xfd,0xfb};
unsigned char disbuff[4] ={ 0,0,0,0,};
unsigned char posit=0;
unsigned char pwm_val_left = 0;//变量定义
unsigned char push_val_left =14;//舵机归中,产生约,1.5MS 信号
unsigned long S=0;
unsigned long S1=0;
unsigned long S2=0;
unsigned long S3=0;
unsigned long S4=0;
unsigned int time=0; //时间变量
unsigned int timer=0; //延时基准变量
unsigned char timer1=0; //扫描时间变量
void delay(unsigned int k) //延时函数
{
unsigned int x,y;
for(x=0;x
for(y=0;y<2000;y++);
}
void display(void) //扫描数码管
{
if(posit==0)
{P0=(discode[disbuff[posit]])&0x7f;}//产生点
else
{P0=discode[disbuff[posit]];}
if(posit==0)
{ P2_1=0;P2_2=1;P2_3=1;}
if(posit==1)
{P2_1=1;P2_2=0;P2_3=1;}
if(posit==2)
{P2_1=1;P2_2=1;P2_3=0;}
if(++posit>=3)
posit=0;
}
void StartModule() //启动测距信号
{
TRIG=1;
_nop_();
_nop_();
_nop_();
_nop_();
_nop_();
_nop_();
_nop_();
_nop_();
_nop_();
_nop_();
_nop_();
_nop_();
_nop_();
_nop_();
_nop_();
_nop_();
_nop_();
_nop_();
_nop_();
_nop_();
_nop_();
TRIG=0;
}
void Conut(void) //计算距离
{
while(!ECHO); //当RX为零时等待
TR0=1; //开启计数
while(ECHO); //当RX为1计数并等待
TR0=0; //关闭计数
time=TH0*256+TL0; //读取脉宽长度
TH0=0;
TL0=0;
S=(time*1.7)/100; //算出来是CM
disbuff[0]=S%1000/100; //更新显示
disbuff[1]=S%1000%100/10;
disbuff[2]=S%1000%10 %10;
}
//前速前进
void run(void)
{ Left_moto_back ;
//Left_moto_go ; //左电机往前走
Right_moto_go ; //右电机往前走
}
//前速后退
void backrun(void)
{ Left_moto_go ;
//Left_moto_back ; //左电机往前走
Right_moto_back ; //右电机往前走
}
//左转
void leftrun(void)
{ Left_moto_go ;
//Left_moto_back ; //左电机往前走
Right_moto_go ; //右电机往前走
}
//右转
void rightrun(void)
{ Left_moto_back ;
//Left_moto_go ; //左电机往前走
Right_moto_back ; //右电机往前走
}
/************************************************************************/
//STOP
void stoprun(void)
{
Left_moto_Stop ; //左电机停走
Right_moto_Stop ; //右电机停走
}
/************************************************************************/
void COMM( void )
{
push_val_left=5; //舵机向左转90度
timer=0;
while(timer<=4000); //延时400MS让舵机转到其位置
StartModule(); //启动超声波测距
Conut(); //计算距离
S2=S;
push_val_left=23; //舵机向右转90度
timer=0;
while(timer<=4000); //延时400MS让舵机转到其位置
StartModule(); //启动超声波测距
Conut(); //计算距离
S4=S;
push_val_left=14; //舵机归中
timer=0;
while(timer<=4000); //延时400MS让舵机转到其位置
StartModule(); //启动超声波测距
Conut(); //计算距离
S1=S;
if((S2<20)||(S4<20)) //只要左右各有距离小于,20CM小车后退
{
backrun(); //后退
timer=0;
while(timer<=4000);
}
if(S2>S4)
{
rightrun(); //车的左边比车的右边距离小 右转
timer=0;
while(timer<=4000);
}
else
{
leftrun(); //车的左边比车的右边距离大 左转
timer=0;
while(timer<=4000);
}
}
void pwm_Servomoto(void)
{
if(pwm_val_left<=push_val_left)
Sevro_moto_pwm=1;
else
Sevro_moto_pwm=0;
if(pwm_val_left>=200)
pwm_val_left=0;
}
///*TIMER1中断服务子函数产生PWM信号*/
void time1()interrupt 3 using 2
{
TH1=(65536-100)/256; //100US定时
TL1=(65536-100)%256;
timer++; //定时器100US为准。在这个基础上延时
pwm_val_left++;
pwm_Servomoto();
timer1++; //2MS扫一次数码管
if(timer1>=20)
{
timer1=0;
Display();
}
}
///*TIMER0中断服务子函数产生PWM信号*/
void timer0()interrupt 1 using 0
{
}
void main(void)
{
TMOD=0X11;
TH1=(65536-100)/256; //100US定时
TL1=(65536-100)%256;
TH0=0;
TL0=0;
TR1= 1;
ET1= 1;
ET0= 1;
EA = 1;
delay(100);
push_val_left=14; //舵机归中
while(1) /*无限循环*/
{
if(timer>=1000) //100MS检测启动检测一次
{
timer=0;
StartModule(); //启动检测
Conut(); //计算距离
if(S<30) //距离小于20CM
{
stoprun(); //小车停止
COMM(); //方向函数
}
else
if(S>35) //距离大于,30CM往前走
run();
}
}
}
蜂鸣器音乐《天空之城》
#include
sbit sound=P2^0; //将sound位定义为P2.0
unsigned int C; //储存定时器的定时常数
//低音的音频宏定义
#define l_dao 262 //将“l_dao”宏定义为低音“1”的频率262Hz
#define l_re 286 //将“l_re”宏定义为低音“2”的频率286Hz
#define l_mi 311 //将“l_mi”宏定义为低音“3”的频率311Hz
#define l_fa 349 //将“l_fa”宏定义为低音“4”的频率349Hz
#define l_sao 392 //将“l_sao”宏定义为低音“5”的频率392Hz
#define l_la 440 //将“l_a”宏定义为低音“6”的频率440Hz
#define l_xi 494 //将“l_xi”宏定义为低音“7”的频率494Hz
//中音的音频宏定义
#define dao 523 //将“dao”宏定义为中音“1”的频率523Hz
#define re 587 //将“re”宏定义为中音“2”的频率587Hz
#define mi 659 //将“mi”宏定义为中音“3”的频率659Hz
#define fa 698 //将“fa”宏定义为中音“4”的频率698Hz
#define sao 784 //将“sao”宏定义为中音“5”的频率784Hz
#define la 880 //将“la”宏定义为中音“6”的频率880Hz
#define xi 987 //将“xi”宏定义为中音“7”的频率523H
//高音的音频宏定义
#define h_dao 1046 //将“h_dao”宏定义为高音“1”的频率1046Hz
#define h_re 1174 //将“h_re”宏定义为高音“2”的频率1174Hz
#define h_mi 1318 //将“h_mi”宏定义为高音“3”的频率1318Hz
#define h_fa 1396 //将“h_fa”宏定义为高音“4”的频率1396Hz
#define h_sao 1567 //将“h_sao”宏定义为高音“5”的频率1567Hz
#define h_la 1760 //将“h_la”宏定义为高音“6”的频率1760Hz
#define h_xi 1975 //将“h_xi”宏定义为高音“7”的频率1975Hz
void delay1()
{
unsigned char i,j;
for(i=0;i<250;i++)
for(j=0;j<250;j++)
;
}
void main(void)
{
unsigned char i,j;
//以下是《天空之城》片头曲的一段简谱
unsigned int code f[]={dao,l_xi,dao,mi,l_dao,l_mi, //【6】1713 7--3(天空之城简谱表)
l_la,l_sao,l_la,dao,l_sao,l_mi, //【6】6561 5--3
l_fa,l_mi,l_fa,dao,dao,l_mi,dao, //【7】43411 3--1
l_xi,l_fa,l_fa,l_xi,l_xi,l_la,l_xi, //【7】7447 7-067
dao,l_xi,dao,mi,l_xi,l_mi,l_mi, //【7】1713 7--33
l_la,l_sao,l_la,dao,l_sao,l_mi, //【6】6561 5--3
l_fa,dao,l_xi,l_xi,dao,re,mi,dao, //【8】41771 231-0
dao,l_xi,l_la,l_xi,l_sao,l_la,dao,re,//【8】17675 6-012
mi,re,mi,fa,sao,re,l_sao, //【7】32345 2--5
re,dao,l_xi,dao,dao,dao,re,mi, //【8】21711123
mi, //【1】3---
l_la,l_xi,dao,l_xi,dao,re,dao,l_sao,l_sao,//【9】671712 155-
fa,mi,re,dao,mi,l_la,l_xi, //【7】4321 3--67
dao,l_xi,dao,mi,l_xi,l_mi, //【6】1713 7--3
l_la,l_sao,l_la,dao,l_sao,l_mi, //【6】6561 5--3
l_fa,dao,l_xi,l_xi,dao,re,mi,dao,dao,//【9】41771 2311-
dao,l_xi,l_la,l_xi,l_sao,l_la, //【6】17675 6---
0xff}; //【1*】以0xff作为音符的结束标志
//以下是简谱中每个音符的节拍
//"4"对应4个延时单位,"2"对应2个延时单位,"1"对应1个延时单位
unsigned char code JP[ ]={3,2,4,4,10,4, //【6】
6,2,4,4,10,4, //【6】
6,2,2,2,4,10,4, //【7】
6,2,4,4,6,2,2, //【7】
6,2,4,4,10,2,2, //【7】
6,2,4,4,10,4, //【6】
4,2,2,4,4,4,2,8, //【8】
2,2,4,4,4,10,2,2, //【8】
6,4,4,4,2,10,4, //【7】
1,1,1,1,4,4,4,4, //【8】
10, //【1】
2,2,4,2,2,4,6,4,8, // 【9】
4,4,4,4,10,2,2, //【7】
4,2,4,4,10,4, //【6】
6,2,4,4,10,4, //【6】
4,2,2,4,4,4,2,2,8, //【9】
2,2,4,4,4,10, //【6】
10 //【1*】
};
EA=1; //开总中断
ET0=1; //定时器T0中断允许
TMOD=0x00; // 使用定时器T0的模式1(13位计数器)
while(1) //无限循环
{
i=0; //从第1个音符f[0]开始播放
while(f!=0xff) //只要没有读到结束标志就继续播放
{
C=460830/f;
TH0=(8192-C)/32; //可证明这是13位计数器TH0高8位的赋初值方法
TL0=(8192-C)%32; //可证明这是13位计数器TL0低5位的赋初值方法
TR0=1; //启动定时器T0
for(j=0;j
delay1(); //延时1个节拍单位
TR0=0; //关闭定时器T0
i++; //播放下一个音符
}
}
}
void Time0(void ) interrupt 1 using 1
{
sound=!sound; //将P1.5引脚输出电平取反,形成方波
TH0=(8192-C)/32; //可证明这是13位计数器TH0高8位的赋初值方法
TL0=(8192-C)%32; //可证明这是13位计数器TL0低5位的赋初值方法
}
0
python蜂鸣器天空之城频率_如何把两个程序合在一起实现(小车超声波避障+蜂鸣器音乐《天空之城》)...相关推荐
- stm32捕获占空比_基于STM32超声波避障小车
不管是对于初学者还是对于一个玩过单片机的电子爱好者来说,或多或少都接触到过小车项目,今天给大家介绍的的一个项目基于STM32超声波避障小车.这也是我曾经的一个课设,在此开源分享给大家,全文5000多字 ...
- 收发一体超声波测距离传感器模块_超声波避障传感器在哪些地方运用
近年来随着移动机器人.无人驾驶汽车以及无人机的发展,对避障传感器需求越来越多.传统的可用来避障的传感器有毫米波雷达.激光雷达.双目视觉传感器.超声波传感器.红外测距传感器.激光测距仪.光电漫反射传感器 ...
- 传感器怎么获取障碍物的宽度信息_超声波避障传感器助力AGV小车轻松实现自动规避障碍物...
原标题:超声波避障传感器助力AGV小车轻松实现自动规避障碍物 近年来,无人化这个概念逐渐被运用到了社会中的各个行业,比如无人零售.无人驾驶.无人工厂:而跟物流有关的就有无人分拣机器人.无人驾驶卡车和无 ...
- python haskell 使用对比_性能-为什么这个Haskell程序比等效的Python程序慢得多?
作为编程挑战的一部分,我需要从stdin读取以空格分隔的整数序列(在一行上),并将这些整数的总和输出到stdout. 所讨论的序列可以包含多达10,000,000个整数. 我有两种解决方案:一种是用H ...
- python蜂鸣器天空之城频率_用python来一首钢琴solo天空之城
winsound模块提供对Windows平台的基本声音播放功能的访问. 别的没啥多说的.自己跑一下体会吧 from winsound import Beep def sound(): Beep(8 ...
- 两个python文件怎么联系在一起_一个连接两个文件的python脚本
公司在阿里云上有一个模块叫mrs,一共120台,它是跟云录像有关的,这个服务一直都是云服务器里没有公网但是购买了公网SLB,然后20个为一组配置到一个SLB里,这个SLB是按流量收费的.但是最近到了年 ...
- python与材料计算公式_《从问题到程序:用Python学编程和计算》——2.11 补充材料-阿里云开发者社区...
本节书摘来自华章计算机<从问题到程序:用Python学编程和计算>一书中的第2章,第2.11节,作者 裘宗燕,更多章节内容可以访问云栖社区"华章计算机"公众号查看. 2 ...
- python编译为机器码_通过 GraalVM 将 Java 程序编译成本地机器码!
前言 2018年4月,Oracle Labs新公开了一项黑科技:Graal VM. 这是一个在HotSpot虚拟机基础上增强而成的跨语言全栈虚拟机,可以作为"任何语言"的运行平台使 ...
- python 项目学编程_《从问题到程序:用Python学编程和计算》——3.5 练习-阿里云开发者社区...
复习下面概念:数值积分,区间分割法,舍入误差,简单重复,累积,累积变量,生成和筛选,递推,递推变量,素数(质数),因子和真因子,哥德巴赫猜想,输入循环,输入控制的循环,递归定义,递归函数,循环定义,无 ...
最新文章
- 软件架构师证书有用吗_健康管理师证书在求职时有用吗?
- seaborn使用jointplot函数为散点图添加边缘图、添加回归线、为边缘直方图添加密度曲线、自定义边缘直方图的箱体个数bins(Number of Bins to Marginal Plot )
- Aruba发布全新集成资产追踪解决方案及核心交换机
- MySql基础入门-mysql体系结构
- 数据包通过分层模型实现通信的过程
- svn 403 Forbidden
- OpenShift 4 - 用Buildah定制UBI容器镜像
- linux实现多台服务器文件同步
- 用python写WordCount的MapReduce代码
- 多幸运用计算机演奏的乐谱,多幸运钢琴简谱-数字双手-韩安旭
- 奥布莱恩杯尘埃落定 人工智能立功了!
- Cassandra的Allow Filtering
- Deferred异步操作
- 使用 Let‘s Encrypt 为 Zimbra-8.8.15 安装可信任的SSL证书
- 射频基础——射频同轴线缆介绍
- 计算机行业到底还能火多久?
- 【资源】重磅!清华大学网上课程面向全国免费开放!无需登录、注册!在家上清华!...
- abp项目怎样发布到服务器,ABP 网站发布
- http client 短链接复用(变为长连接)
- 美国H1B基本情况及相关数据
热门文章
- CSS-0813(重复性)线性/径向渐变-过渡属性transition-变形属性transform变形位移旋转缩放倾斜视域函数perspective变形原点三角形居中方法
- Python爬虫——动漫zj(manhua站)
- Hbase的Regina分区
- JAVA架构之路(DDD架构模型)
- 删除下拉框只找23火星软件_下拉框关键词软件只找23火星下拉框词工具佳选火星...
- R12供应商银行账户SQL
- 一条sql查询出多个统计结果
- MX,Y,Z代表力矩 代表什么的力矩
- 安装TIA博途V14 SP1后,打开软件时系统提示出现一个并行的错误_解决办法
- 年终重磅盘点:2022计算机科学6大突破!破解量子加密、最快矩阵乘法等榜上有名...