请问labview程序中的全桥1,全桥2,全桥3或者半桥1,半桥2之间有什么区别啊????

请问labview程序中的全桥1,全桥2,全桥3或者半桥1,半桥2之间有什么区别啊????,第1张

全桥I是在试件上下两面分别贴两应变片,共4片,贴法为 = ,适合测拉伸应变;全桥II是上下两面分别贴两应变片,共4片,贴法为 T,适合测弯曲应变,横向的贴片的应变要乘泊松系数,且为负应变;全桥III与全桥II贴面方法一样,接线不同,适合测拉伸应变。半桥I贴面为只贴1面,与全II,全III贴法类似,适合测拉压或弯曲;半II与全I类似,贴2面各1片,适合测弯曲应变。具体的还需要找些资料参考,我只能简述

#include <avr/io.h>

void main(void)

{

PORTB=0x00

DDRB=0x0E

// T/C1 初始化

TCCR1A=0xA1

TCCR1B=0x09 //匹配时清零,TOP:255,频率:8M/256=31.25K

OCR1A=85 //占空比:1/3

OCR1B=128 //占空比:1/2

// T/C2 初始化

TCCR2=0x69 //匹配时清零,TOP:255,频率:31.25K

OCR2=170 //占空比:2/3

while (1)

}

使用M16产生三路PWM的程序,参考一下基本OK

还有个是可调节的PWM程序,我做过仿真了,需要全部留下邮箱传给你

/*****************************************************

#define KEY PINC.0

#define PWMA PORTB.3 //17号脚

#define PWMB PORTB.4 //18号脚

#include <mega8.h>

#include <delay.h>

#include <math.h>

unsigned int m=0

unsigned char xiangxian=0

bit INIT2=0//判断是否象限2已经初始化;

bit INIT3=0

bit INIT4=0

/*下面为四个象限中处理函数,参数为45度平分为255段角度*/

inline panduan()

{

if(m<=255)

{

xiangxian=1

}

else if((m>255)&&(m<511))

{

xiangxian=2

if(m==256)

{

INIT2=1

PWMA=0

OCR1A=0x00

OCR1B=0xff

PWMB=1

}

}

else if((m>=511)&&(m<767))

{

xiangxian=3

}

else if((m>=767)&&(m<1024))

{

xiangxian=4

}

else if(m>1024)

{

m=0

}

}

void xiangxian1(unsigned char degree)

{

PWMA=0

PWMB=0

OCR1BL=m

OCR1AL=255-m

}

void xiangxian2(unsigned char degree)

{ unsigned char temp

temp=m-255

OCR1AL=temp

OCR1BL=temp

}

void xiangxian3(unsigned char degree)

{

unsigned char temp

temp=m-511

PWMA=1

PWMB=1

OCR1BL=255-temp

OCR1AL=temp

}

void xiangxian4(unsigned char degree)

{unsigned char temp=0

temp=m-767

PWMA=1

PWMB=0

OCR1BL=255-temp

OCR1AL=255-temp

}

/*角度计算函数,负责计算在各个象限中角度对应的PWM输出*/

void SET_ANGLE( unsigned char degree)

{

switch (xiangxian)

{

case 1: xiangxian1(degree)break

case 2: xiangxian2(degree)break

case 3: xiangxian3(degree)break

case 4: xiangxian4(degree)break

default:break

}

}

void main(void)

{

unsigned char temp

unsigned char xiangxian=0

// Declare your local variables here

PORTB=0x187

DDRB=0x1e

// Port C initialization

// Func6=In Func5=In Func4=In Func3=In Func2=In Func1=In Func0=In

// State6=T State5=T State4=T State3=T State2=T State1=T State0=P

PORTC=0x01

DDRC=0x00

// Port D initialization

// Func7=In Func6=In Func5=In Func4=In Func3=In Func2=Out Func1=In Func0=In

// State7=T State6=T State5=T State4=T State3=T State2=0 State1=T State0=T

PORTD=0x00

DDRD=0x04

// Timer/Counter 0 initialization

// Clock source: System Clock

// Clock value: Timer 0 Stopped

TCCR0=0x00

TCNT0=0x00

// Timer/Counter 1 initialization

// Clock source: System Clock

// Clock value: 1000.000 kHz

// Mode: Fast PWM top=01FFh

// OC1A output: Inverted

// OC1B output: Inverted

// Noise Canceler: Off

// Input Capture on Falling Edge

// Timer 1 Overflow Interrupt: Off

// Input Capture Interrupt: Off

// Compare A Match Interrupt: Off

// Compare B Match Interrupt: Off

TCCR1A=0xF1

TCCR1B=0x01

TCNT1H=0x00

TCNT1L=0x00

ICR1H=0x00

ICR1L=0x00

OCR1AH=0x00

OCR1AL=0x00

OCR1BH=0x00

OCR1BL=0x00

// Timer/Counter 2 initialization

// Clock source: System Clock

// Clock value: Timer 2 Stopped

// Mode: Normal top=FFh

// OC2 output: Disconnected

ASSR=0x00

TCCR2=0x00

TCNT2=0x00

OCR2=0x00

// External Interrupt(s) initialization

// INT0: Off

// INT1: Off

MCUCR=0x00

// Timer(s)/Counter(s) Interrupt(s) initialization

TIMSK=0x00

// Analog Comparator initialization

// Analog Comparator: Off

// Analog Comparator Input Capture by Timer/Counter 1: Off

ACSR=0x80

SFIOR=0x00

PWMA=0

PWMB=0

OCR1AL=0xff

OCR1BL=0x00

while (1)

{

if(KEY==0)

{

delay_ms(20)

if(KEY==0)

{

m=m+1

panduan()

SET_ANGLE(m)

PORTD.2=!PORTD.2

}

}

}

}

如果是自己写的程序的话,你先把PWM管脚配置成普通I/O口模式,然后用这个I/O口发送高电平和低电平,看看示波器里的波形是不是随着你的设置变化,如果有变化,说明PWM管脚的后级电路有问题或者是你测量位置、示波器使用等有问题点。先一步一步测吧。


欢迎分享,转载请注明来源:内存溢出

原文地址:https://54852.com/yw/12130196.html

(0)
打赏 微信扫一扫微信扫一扫 支付宝扫一扫支付宝扫一扫
上一篇 2023-05-21
下一篇2023-05-21

发表评论

登录后才能评论

评论列表(0条)

    保存