c語言編程adc,C語言編程題

本文目錄一覽:

C語言程序設計, char s[]=“adc\0def” strlen(s)=? sizeo

s[]=”abc\0def”,因為是字符串,所以實際存儲為’a’,’b’,’c’,’\0′,’d’,’e’,’f’,’\0′

一共是8個字符,sizeof(s)是統計s的字節數,而一個字符佔一個字節,所以sizeof(s)的結果是8,strlen(s)是統計s的長度,以’\0’字符為結束,所以是3

51單片機 C語言ADC程序怎麼寫

typedef unsigned char BYTE;

typedef unsigned int WORD;

#include “reg51.h”

#include “intrins.h”

/*Declare SFR associated with the ADC */

sfr ADC_CONTR = 0xBC;

sfr ADC_RES = 0xBD;

sfr ADC_LOW2 = 0xBE;

sfr P1ASF = 0x9D;

sfr P2M0 = 0x96;

sfr P2M1 = 0x95;

/*Define ADC operation const for ADC_CONTR*/

#define ADC_POWER 0x80

#define ADC_FLAG 0x10

#define ADC_START 0x08

#define ADC_SPEEDLL 0x00

#define ADC_SPEEDL 0x20

#define ADC_SPEEDH 0x40

#define ADC_SPEEDHH 0x60

//延時

void Delay(WORD n)

{

WORD x;

while (n–)

{

x = 5000;

while (x–);

}

}

//初始AD寄存器

void InitADC()

{

P1ASF = 0xff;

ADC_RES = 0;

ADC_CONTR = ADC_POWER | ADC_SPEEDLL;

Delay(2);

}

//AD轉換

BYTE GetADCResult(BYTE ch)

{

ADC_CONTR = ADC_POWER | ADC_SPEEDLL | ch | ADC_START;

_nop_();

_nop_();

_nop_();

_nop_();

while (!(ADC_CONTR ADC_FLAG));

ADC_CONTR = ~ADC_FLAG;

return ADC_RES;

}

void main()

{ BYTE temp;

P2M1=0; P2M0=0x03; //P2.0和P2.1強推挽

InitADC();

while (1)

{

temp=GetADCResult(0);//轉換P1.0

if(temp1)

P2|=0x03; //P1.0有電壓 P2.0和P2.1輸出高

else

P2=0xFC; //P1.0無電壓 P2.0和P2.1輸出低

}

}

51單片機c語言,ADC模數轉換的問題

對於這個,要這麼看:

假設中斷A是優先級高的中斷,中斷B是優先級低的中斷

如果在正常執行的過程中,發生中斷A,那麼,中斷A執行完成後,會返回正常程序;

如果在正常執行過程中,發生中斷B,又在中斷B處理過程中發生中斷A,那麼,中斷A執行完成後,一定要返回的是中斷B,這是由硬件決定的,不是軟件決定的,所以,軟件沒有任何指令可以讓中斷A執行完成後直接跳過還沒有執行完的中斷B而直接回到主程序,因為這是硬件決定的,軟件做不到,即便你在高級中斷A中關閉了中斷B,但是因為你原來的中斷B還沒有執行完,所以,仍然要把沒執行完的部分執行下去,才能返回到正常程序.

對於ARM系列的可以,對於51來說,是不行的,因為51軟件指令不允許修改PC寄存器的值

AVR單片機ADC控制LED程序(C語言)

給你寫一個吧,反正很簡單一個程序,用mega8實現,單片機型號你可以改,只要改掉中斷向量號就行:

#include iom8v.h

#include macros.h

#define LED1_ON PORTB|= BIT(1)

#define LED1_OFF PORTB=~BIT(1)

//一下你可以再寫七個燈或者更多

#define uchar unsigned char

#define uint unsigned int

uint adc_count = 0 ; //控制AD轉換速度計數

uint a_time = 0 ; //用於AD數字濾波計數

uchar mode = 0 ; //用於AD處理結果賦值

void port_init(void)

{

DDRB = 0xff;

PORTB = 0x00;

DDRC = 0x00;

PORTC = 0xff;

DDRD = 0xf0;

PORTD = 0x00;

}

// 定時器分頻: 64

// 設定定時值: 1ms

// 真實定時值: 1ms (0.0%)

void timer0_init(void)

{

TCCR0 = 0x00; //stop

TCNT0 = 0x83; //set count

TIMSK |= 0x01;

TCCR0 = 0x03; //start timer

}

#pragma interrupt_handler timer0_ovf_isr:10

void timer0_ovf_isr(void)

{

TCNT0 = 0x83; //reload counter value

adc_count++;

if(adc_count==50) //用於控制AD轉換速度

{

adc_count=0;

ADCSRA = 0xCF;

}

else

{

ADCSRA = 0x00;

}

}

void adc_init(void)

{

ADCSRA = 0x00; //禁止AD轉換

ADMUX = 0x07;

SFIOR |= 0x00;

ACSR = 0x80; //禁止模擬比較器

ADCSRA = 0xCF;

//ADCSRA = 0xED;

}

unsigned int adc_calc(void)

{

//計算實際電壓

unsigned long value=0;

unsigned int voltage=0; //電壓單位為(mV)

value=ADCL; //首先讀低位

value|=(int)ADCH 8; //然後讀高位

voltage=(value*5000)/1023;

ad_flag=1;

return voltage;

}

//採用AD取平均值的方式

#pragma interrupt_handler adc_isr:15

void adc_isr(void)

{

//轉換完成後中斷處理

unsigned int voltage1;

a_time++;

if(a_time8)

{voltage1=adc_calc();voltage2=voltage2+voltage1;}//數字濾波

while(a_time==8)

{

a_time=0;voltage=voltage2/8;voltage2=0;

if((voltage)1130){dianliang=0;}

if((voltage=1130)(voltage1300)){mode=1;}

if((voltage=1300)(voltage1560)){mode=2;}

if((voltage=1560)(voltage1750)){mode=3;}

if((voltage=1750)(voltage1950)){mode=4;}

if((voltage=1950)(voltage2150)){mode=5;}

if((voltage=2150)(voltage2341)){mode=6;}

if((voltage=2341)(voltage2560)){mode=7;}

if((voltage=2560)(voltage2710)){mode=8;}

if((voltage=2710)(voltage2870)){mode=9;}

}

else{mode=0;}

}

void LED_DISP(void) //用於控制LED顯示

{

switch(mode)

{

case 0: /*此處寫上你要控制的燈的亮或滅*/ ;break;

case 1: /*此處寫上你要控制的燈的亮或滅*/ ;break;

case 2: /*此處寫上你要控制的燈的亮或滅*/ ;break;

case 3: /*此處寫上你要控制的燈的亮或滅*/ ;break;

case 4: /*此處寫上你要控制的燈的亮或滅*/ ;break;

case 5: /*此處寫上你要控制的燈的亮或滅*/ ;break;

case 6: /*此處寫上你要控制的燈的亮或滅*/ ;break;

case 7: /*此處寫上你要控制的燈的亮或滅*/ ;break;

case 8: /*此處寫上你要控制的燈的亮或滅*/ ;break;

case 9: /*此處寫上你要控制的燈的亮或滅*/ ;break;

default: break;

}

}void init_devices(void)

{

CLI(); //禁止所有中斷

MCUCR = 0x00;

MCUCSR = 0x80;//禁止JTAG

GICR = 0x00;

timer0_init();

port_init();

adc_init();

//SEI();//開全局中斷

}

void main(void)

{

init_devices();

while(1)

{

LED_DISP();

}

}

C語言實現ADC採樣問題

我的理解是這樣的:

我不知道ADC_TEMP 是否已經被初始化為零了。如果是,思路就是這樣 0000 0000 0000 0000 0000 0000 這是ADC_temp,AD_DATA 應該就是採樣的 每一位 的數 比如採樣你說的 101101,其實應該把前面的0補齊,也就是0000 0000 0000 0000 0010 1101 。然後經過for循環,從第一位開始取,當遇到1的時候,執行ADC_temp|= 1; 我們知道或運算的規則,1和什麼都是1。所以就從第一位0開始取,直到取完最後一位,每取一位左移一位,再和輸出的AD_DATA 或運算。前提是,這個AD_DATA是高位輸出。

原創文章,作者:OJCL,如若轉載,請註明出處:https://www.506064.com/zh-hant/n/137645.html

(0)
打賞 微信掃一掃 微信掃一掃 支付寶掃一掃 支付寶掃一掃
OJCL的頭像OJCL
上一篇 2024-10-04 00:17
下一篇 2024-10-04 00:17

相關推薦

  • AES加密解密算法的C語言實現

    AES(Advanced Encryption Standard)是一種對稱加密算法,可用於對數據進行加密和解密。在本篇文章中,我們將介紹C語言中如何實現AES算法,並對實現過程進…

    編程 2025-04-29
  • 學習Python對學習C語言有幫助嗎?

    Python和C語言是兩種非常受歡迎的編程語言,在程序開發中都扮演着非常重要的角色。那麼,學習Python對學習C語言有幫助嗎?答案是肯定的。在本文中,我們將從多個角度探討Pyth…

    編程 2025-04-29
  • Python被稱為膠水語言

    Python作為一種跨平台的解釋性高級語言,最大的特點是被稱為”膠水語言”。 一、簡單易學 Python的語法簡單易學,更加人性化,這使得它成為了初學者的入…

    編程 2025-04-29
  • OpenJudge答案1.6的C語言實現

    本文將從多個方面詳細闡述OpenJudge答案1.6在C語言中的實現方法,幫助初學者更好地學習和理解。 一、需求概述 OpenJudge答案1.6的要求是,輸入兩個整數a和b,輸出…

    編程 2025-04-29
  • Python按位運算符和C語言

    本文將從多個方面詳細闡述Python按位運算符和C語言的相關內容,並給出相應的代碼示例。 一、概述 Python是一種動態的、面向對象的編程語言,其按位運算符是用於按位操作的運算符…

    編程 2025-04-29
  • Python語言由荷蘭人為中心的全能編程開發工程師

    Python語言是一種高級語言,很多編程開發工程師都喜歡使用Python語言進行開發。Python語言的創始人是荷蘭人Guido van Rossum,他在1989年聖誕節期間開始…

    編程 2025-04-28
  • Python語言設計基礎第2版PDF

    Python語言設計基礎第2版PDF是一本介紹Python編程語言的經典教材。本篇文章將從多個方面對該教材進行詳細的闡述和介紹。 一、基礎知識 本教材中介紹了Python編程語言的…

    編程 2025-04-28
  • Python語言實現人名最多數統計

    本文將從幾個方面詳細介紹Python語言實現人名最多數統計的方法和應用。 一、Python實現人名最多數統計的基礎 1、首先,我們需要了解Python語言的一些基礎知識,如列表、字…

    編程 2025-04-28
  • Python作為中心語言,在編程中取代C語言的優勢和挑戰

    Python一直以其簡單易懂的語法和高效的編碼環境而著名。然而,它最近的發展趨勢表明Python的使用範圍已經從腳本語言擴展到了從Web應用到機器學習等廣泛的開發領域。與此同時,C…

    編程 2025-04-28
  • Python基礎語言

    Python作為一種高級編程語言擁有簡潔優雅的語法。在本文中,我們將從多個方面探究Python基礎語言的特點以及使用技巧。 一、數據類型 Python基礎數據類型包括整數、浮點數、…

    編程 2025-04-28

發表回復

登錄後才能評論