色哟哟视频在线观看-色哟哟视频在线-色哟哟欧美15最新在线-色哟哟免费在线观看-国产l精品国产亚洲区在线观看-国产l精品国产亚洲区久久

0
  • 聊天消息
  • 系統消息
  • 評論與回復
登錄后你可以
  • 下載海量資料
  • 學習在線課程
  • 觀看技術視頻
  • 寫文章/發帖/加入社區
會員中心
創作中心

完善資料讓更多小伙伴認識你,還能領取20積分哦,立即完善>

3天內不再提示

DALI通信的原理及實現方法

CHANBAEK ? 來源:博客園-斑鳩,一生。 ? 作者:博客園-斑鳩,一生 ? 2023-03-08 14:58 ? 次閱讀

在雙碳目標下,具有調光功能的LED驅動電源是重要的分支。 DALI通信常用在LED的數字調光控制中,下文將通過C語言單片機結合,解釋DALI的原理及實現方法。

一、通信原理

1.1 DALI 的物理電平信號定義如下:

9.5~22.5V: 高電平或者DALI 空閑狀態

6.5~9.5V: 未定義

-6.5V~6.5V:定義為低電平


1.2 波特率:1200bps + 10%

1.3 DALI 負載最大短路電流<250mA

當從機發生故障,例如短路時,DALI總線上的電流,需要限制在250mA以下。

1.4 編碼方式

使用曼切斯特編碼,即上升沿為信號1,下降沿為信號0。

1.5 主機發送指令結構

主機發送的包含1個起始位、1個地址位類型位、6個地址位、一個選擇位、8個數據位和兩個停止位。

1.6 從機回復指令結構

從機向主機回復包含1個起始位、8個數據位和兩個停止位。

1.7 前向幀與后向幀時序約束

Te表示半個位的時間,即4.16.67uS;

兩個前向幀時間間隔大于22個Te;

前向幀與后向幀之間時間間隔為7~22個Te;

后向幀與前向幀之間時間間隔大于22個Te;

1.8 主機與從機的握手

主機在發送指令后,在等候響應階段,

如果收到從機發送的”0xFF“,就會認為從機接收成功;

如果在這個階段處于空閑狀態,就會認為從機沒有接收成功;

二、實現方法

2.1 硬件原理圖

下面的硬件主要是將DALI的電平信號,轉為單片機能夠接受的電平,下面那張是微芯公司DALI的參考通信電路。

2.1 從機接收思路及實現

本次從機的接收端,主要使用了一個邊沿檢測中斷和一個定時器中斷。

代碼思路:

1)由于空閑狀態,接收端的電平為高電平,產生起始信號時,需要從產生一個上升沿。 于是,使用了外部下降沿觸發中斷,并關閉邊沿觸發中斷;

2)檢測到第一個下降沿后,定時器定時到0.75個周期,0.75個周期后讀取第一位數據,并修改定時器周期為1個數據位時長。

3)第二次定時結束時讀取第二位數據,依次讀取后面的數據

4)當讀到最后一位數據的時候,也就是LSB后的兩位時,停止定時器,并初始化定時器為0.75個數據周期,然后開啟邊沿觸發中斷。

C語言程序:

1 //配置邊沿觸發及中斷
  2 void IO_Change_Init(void){  
  3     
  4     //Set the CN2 as the IO state change flag 
  5     CNEN1bits.CN2IE=1;//Open the IO state interrupt
  6     CNPU1bits.CN2PUE=0;//Disable the weak up
  7     
  8     IFS1bits.CNIF=0;//Clear the interrupt flag
  9     IPC4bits.CNIP=7;//Configure the interrupt level 7
 10     IEC1bits.CNIE=1;//Enable this interrupt
 11 }
 12 //檢測到第一個下降沿
 13 void __attribute__ ((__interrupt__,__no_auto_psv__)) _CNInterrupt(void){
 14    
 15    IFS1bits.CNIF = 0; //Clear the interrupt flag 
 16    
 17    //Disable the IO State Interrupt and start the Time
 18    T1CONbits.TON = 1;
 19    CNEN1bits.CN2IE = 0;
 20    
 21 }
 22 //配置定時器初使周期為0.75個數據位時長
 23 void Tim1_Init(void){
 24     T1CON = 0x0020;
 25     
 26     IEC0bits.T1IE = 1;
 27     IPC0bits.T1IP = 7;
 28     IFS0bits.T1IF = 0;
 29     
 30     TMR1 = 0;
 31     PR1 = 390;
 32     T1CONbits.TON = 0;
 33 }
 34 //在定時器中斷里面讀取數據
 35 void __attribute__((__interrupt__,auto_psv,__shadow__)) _T1Interrupt(void)
 36 {
 37     IFS0bits.T1IF = 0;
 38 
 39     if(LLC_DALI_Rx_Mode == 1)
 40     {
 41         switch(Timer_Num)
 42         {
 43             case 0:
 44                 Timer_Num++;
 45                 T1CONbits.TON = 0; //關閉定時器
 46                 PR1 = 520; //設置下一個定時時長為1個周期
 47                 TMR1 = 0;//初使化定時器初始值
 48                 T1CONbits.TON = 1;//開啟定時器
 49                 break;
 50             case 1:
 51                 if(_RB0 == 1 )Address_temp |= (1<<7);
 52                 Timer_Num++;
 53                 break;
 54             case 2:
 55                 if(_RB0 == 1 )Address_temp |= (1<<6);
 56                 Timer_Num++;
 57                 break;
 58             case 3:
 59                 if(_RB0 == 1 )Address_temp |= (1<<5);
 60                 Timer_Num++;            
 61                 break;
 62             case 4:
 63                 if(_RB0 == 1 )Address_temp |= (1<<4);
 64                 Timer_Num++;
 65                 break;
 66             case 5:
 67                 if(_RB0 == 1 )Address_temp |= (1<<3);
 68                 Timer_Num++;            
 69                 break;
 70             case 6:
 71                 if(_RB0 == 1 )Address_temp |= (1<<2);
 72                 Timer_Num++;        
 73                 break;
 74             case 7:
 75                 if(_RB0 == 1 )Address_temp |= (1<<1);
 76                 Timer_Num++;
 77                 break;
 78             case 8:
 79                 if(_RB0 == 1 )Address_temp |= (1<<0);
 80                 Timer_Num++;
 81                 break;
 82             case 9:
 83                 if(_RB0 == 1 )Command_temp |= (1<<7);
 84                 Timer_Num++;
 85                 break;
 86             case 10:
 87                 if(_RB0 == 1 )Command_temp |= (1<<6);
 88                 Timer_Num++;
 89                 break;
 90             case 11:
 91                 if(_RB0 == 1 )Command_temp |= (1<<5);
 92                 Timer_Num++;
 93                 break;
 94             case 12:
 95                 if(_RB0 == 1 )Command_temp |= (1<<4);
 96                 Timer_Num++;
 97                 break;
 98             case 13:
 99                 if(_RB0 == 1 )Command_temp |= (1<<3);
100                 Timer_Num++;
101                 break;
102             case 14:
103                 if(_RB0 == 1 )Command_temp |= (1<<2);
104                 Timer_Num++;
105                 break;
106             case 15:
107                 if(_RB0 == 1 )Command_temp |= (1<<1);
108                 Timer_Num++;
109                 break;
110             case 16:
111                 if(_RB0 == 1 )Command_temp |= (1<<0);
112                 Timer_Num++;
113                 break;
114             case 17:
115                 if(_RB0 == 1 )StopBit_temp |= (1<<1);
116                 Timer_Num++;
117                 break;
118             case 18:
119                 if(_RB0 == 1 )StopBit_temp |= (1<<0);
120                 Timer_Num++;
121                 break;
122             case 19:
123                    T1CONbits.TON = 0;//關閉定時器
124                    PR1 = 390;//設置下一個定時器周期為0.75個數據位時長
125                    TMR1 = 0;//定時器計數初始值置0
126                    CNEN1bits.CN2IE = 1;//開啟邊沿檢測中斷
127                    //數據獲取,這里還可以添加數據包檢驗程序
128                    Command = Command_temp;
129                    Address = Address_temp;
130                    StopBit = StopBit_temp;
131 
132                    Command_temp = 0;
133                    Address_temp = 0;
134                    StopBit_temp = 0;
135                    Timer_Num = 0;
136                 break;
137         }
138     }
139     
140 
141

2.2 從機思路及實現

從機的回復相對較簡單,只需要在每半個數據位修改輸出引腳的電平。 分別發送1個起始位、8個數據位和兩個停止位。

代碼思路:

1)接收數據完成并定時等待8Te

2)發送一個引腳低電平,并設置下一個定時周期為Te,定時器初使值為0,并開啟定時器;

3)在后面的定時器中斷里面,發送起始位;

4)在后面的定時器中斷里面,發送數據位;

5)在后面的定時器中斷里面,發送停止位;

6)初使化發送數據計數變量,初始化定時器計數值為零,關閉定時器;

7)開啟邊沿觸發中斷;

C語言程序實現

1   if(LLC_DALI_Tx_Mode == 1){
 2         switch(Timer_Num)
 3         {
 4             case 0:
 5                 //Send the Start Bit
 6                 _RF3 = 0;
 7                 T1CONbits.TON = 0;
 8                 PR1 = 260;
 9                 TMR1 = 0;
10                 T1CONbits.TON = 1;
11                 Timer_Num++;
12                 break;
13             case 1:
14                 _RF3 = 1;
15                 Timer_Num++;
16                 break;
17             case 2:
18                  //Send the Data Bits
19                 _RF3 = ((Transfer_Data & 0x80)>0)?0:1;
20                 Timer_Num++;
21                 break;
22             case 3:
23                 _RF3 = ((Transfer_Data & 0x80)>0)?1:0;
24                 Timer_Num++;            
25                 break;
26             case 4:
27                  _RF3 = ((Transfer_Data & 0x40)>0)?0:1;
28                 Timer_Num++;
29                 break;
30             case 5:
31                 _RF3 = ((Transfer_Data & 0x40)>0)?1:0;
32                 Timer_Num++;            
33                 break;
34             case 6:
35                 _RF3 = ((Transfer_Data & 0x20)>0)?0:1;
36                 Timer_Num++;        
37                 break;
38             case 7:
39                 _RF3 = ((Transfer_Data & 0x20)>0)?1:0;
40                 Timer_Num++;
41                 break;
42             case 8:
43                 _RF3 = ((Transfer_Data & 0x10)>0)?0:1;
44                 Timer_Num++;
45                 break;
46             case 9:
47                 _RF3 = ((Transfer_Data & 0x10)>0)?1:0;
48                 Timer_Num++;
49                 break;
50             case 10:
51                 _RF3 = ((Transfer_Data & 0x08)>0)?0:1;
52                 Timer_Num++;
53                 break;
54             case 11:
55                 _RF3 = ((Transfer_Data & 0x08)>0)?1:0;
56                 Timer_Num++;
57                 break;
58             case 12:
59                 _RF3 = ((Transfer_Data & 0x04)>0)?0:1;
60                 Timer_Num++;
61                 break;
62             case 13:
63                 _RF3 = ((Transfer_Data & 0x04)>0)?1:0;
64                 Timer_Num++;
65                 break;
66             case 14:
67                 _RF3 = ((Transfer_Data & 0x02)>0)?0:1;
68                 Timer_Num++;
69                 break;
70             case 15:
71                 _RF3 = ((Transfer_Data & 0x02)>0)?1:0;
72                 Timer_Num++;
73                 break;
74             case 16:
75                 _RF3 = ((Transfer_Data & 0x01)>0)?0:1;
76                 Timer_Num++;
77                 break;
78             case 17:
79                 _RF3 = ((Transfer_Data & 0x01)>0)?1:0;
80                 Timer_Num++;
81                 break;
82             case 18:
83                 //Send the stop bit;
84                 T1CONbits.TON = 0;
85                 TMR1 = 0;
86                 PR1 = 260<<2;
87                 T1CONbits.TON = 1;
88                 _RF3 = 1;
89                 Timer_Num++;
90                 break;
91             case 19:
92                    T1CONbits.TON = 0;  //關閉定時器
93                    CNEN1bits.CN2IE = 1;//開啟邊沿檢測中斷
94                    TMR1 = 0;  //定時器初始值置0
95                    PR1 = 260; //定時器周期設置為Te
96                    Timer_Num = 0;//初使定時器數據位計數
97                 break;
98         }
99     }

三、測試結果

3.1 從機發送測試

從機發送數據100,對應二進制為0b0110 0100,實際發送波形見下圖:

實際發送數據為0b01100100,發送正常。

3.2 主機發送從機識別測試

主機通過上位機發送調光指令為239,從機在線調試識別出來的數據為239。 接收正常。

四、小結

從機的接收程序,定時器的定時步長先是1.5個Te,然后是2個Te;

從機的發送程序,定時器的定時步長為1個Te;

從機的接收程序,邊沿觸發只觸發依次就關閉了。

從機的發送程序,發送完畢開啟邊沿觸發。

在定時器中斷里面,修改下一個定時時長,理論上可以做到每一個定時周期都不一樣,這思維可以用于實現更加復雜的功能。

注意:

1)以上代碼發送和接收是獨立的,沒有遵循通信的時序。 1.7節里面有具體時序要求,根據時序稍做修改就可以啦。

2)本次代碼,沒有考慮到時序有10%的誤差。 有待改善。

聲明:本文內容及配圖由入駐作者撰寫或者入駐合作網站授權轉載。文章觀點僅代表作者本人,不代表電子發燒友網立場。文章及其配圖僅供工程師學習之用,如有內容侵權或者其他違規問題,請聯系本站處理。 舉報投訴
  • 單片機
    +關注

    關注

    6039

    文章

    44583

    瀏覽量

    636600
  • 通信
    +關注

    關注

    18

    文章

    6043

    瀏覽量

    136172
  • C語言
    +關注

    關注

    180

    文章

    7608

    瀏覽量

    137178
  • DALI
    +關注

    關注

    4

    文章

    67

    瀏覽量

    20777
  • 驅動電源
    +關注

    關注

    22

    文章

    407

    瀏覽量

    42392
收藏 人收藏

    評論

    相關推薦

    照明照明控制系統中DALI總線調試方法

    隨著樓宇自動化和照明工業的快速發展,傳統的照明控制逐步被智能控制取代,DALI作為新的智能燈光控制協議,定義了電子鎮流器與控制器之間的通信方式,實現智能照明系統的自動化控制。那么如何快速調試照明控制
    的頭像 發表于 10-22 08:55 ?1.1w次閱讀

    DALI通信協議有什么想法嗎?

    嗨,伙計們,我是DALI的新成員,現在我需要在我的橙色PI零板上實現DALI主協議,有人對硬件要求有什么想法或建議嗎?謝謝。 以上來自于百度翻譯 以下為原文 Hi guys, I am new
    發表于 04-29 13:51

    DALI系統的研究與開發

    DALI協議的開發背景和應用范圍的基礎上,分析了DALI協議的電氣特性,編碼格式和傳輸規則。重點論述了DALI主從式模塊的設計,該模塊采用MC68HC908KX8芯片為CPU,實現
    發表于 08-09 14:50 ?89次下載
    <b class='flag-5'>DALI</b>系統的研究與開發

    使用示波器分析DALI協議

    隨著樓宇自動化和照明工業的快速發展,傳統的照明控制逐步被智能控制取代,DALI作為新的智能燈光控制協議,定義了電子鎮流器與控制器之間的通信方式,實現智能照明系統的自動化控制,那么,如何快速調試照明
    發表于 11-08 11:42 ?12次下載
    使用示波器分析<b class='flag-5'>DALI</b>協議

    Dali通信在智能照明中的應用

    ,通過總線將照明設備連接在一起,實現對照明設備的精確控制。 1.2 Dali通信技術的原理 Dali通信技術
    的頭像 發表于 01-10 10:21 ?84次閱讀

    Dali通信和傳統照明的比較

    控制照明設備。Dali通信可以實現對照明設備的精確控制,包括亮度、色溫等參數。 二、傳統照明的工作原理 傳統照明主要依賴于機械開關和手動調節,用戶需要親自操作開關來控制照明設備的開關和亮度。傳統照明無法
    的頭像 發表于 01-10 10:22 ?75次閱讀

    Dali通信網絡的最佳配置

    DALI(數字可尋址照明接口)通信網絡的最佳配置涉及多個方面,包括網絡架構、設備選擇、布線要求以及功能實現等。以下是對DALI通信網絡最佳配
    的頭像 發表于 01-10 10:32 ?88次閱讀

    Dali通信系統常見故障及解決方法

    Dali通信系統因其高效、靈活和可靠的特點,在現代照明控制領域中得到了廣泛應用。然而,任何系統都有可能遇到故障。 1. 通信故障 1.1 故障現象 控制器無法與Dali設備
    的頭像 發表于 01-10 10:38 ?129次閱讀

    Dali通信的優勢和劣勢

    Dali通信的優勢 1. 數字化控制 Dali通信采用數字信號傳輸,與傳統的模擬控制相比,數字信號更穩定、抗干擾能力強,能夠實現更精確的控制
    的頭像 發表于 01-10 10:40 ?86次閱讀

    Dali通信協議的標準解析

    DALI協議最初由歐洲委員會在1990年代中期開發,旨在為照明控制系統提供一個開放的、標準化的通信接口。DALI協議允許照明設備(如調光器、傳感器和燈具)之間進行雙向通信
    的頭像 發表于 01-10 10:42 ?138次閱讀

    Dali通信與物聯網的結合

    地增強了其能效和用戶體驗。 一、DALI通信協議簡介 DALI協議是一種國際標準的光伏照明控制系統,用于控制和管理照明設備。它支持單線雙向通信,每個燈具都具備唯一地址,可以通過
    的頭像 發表于 01-10 10:45 ?82次閱讀

    Dali通信如何提高能源效率

    實現這一目標提供了有效的技術支持。 一、DALI通信的基本原理 DALI通信協議是一種雙向、可尋址的照明控制協議,它允許單個燈具或燈具組被單
    的頭像 發表于 01-10 10:46 ?74次閱讀

    Dali通信系統的調試指南

    調試通信系統是一個復雜的過程,涉及到對系統性能的測試、故障排除和優化。以下是一個關于調試Dali通信系統的指南,假設Dali是一個特定的通信
    的頭像 發表于 01-10 10:47 ?140次閱讀

    Dali通信與其他通信協議的對比

    DALI協議最初由歐洲照明制造商開發,旨在為照明控制系統提供一個標準化的接口。它支持雙向通信,允許中央控制系統與每個燈具進行通信,從而實現精確的控制和監控。
    的頭像 發表于 01-10 10:51 ?87次閱讀

    Dali通信模塊的選擇與配置

    DALI(數字可尋址照明接口)通信模塊的選擇與配置涉及多個方面,包括網絡架構、設備選擇、布線要求以及功能實現等。以下是對DALI通信模塊選擇
    的頭像 發表于 01-10 10:55 ?92次閱讀
    主站蜘蛛池模板: 国产色精品久久人妻无码看片| 黄色片中文| 灰原哀被啪漫画禁漫| 污污内射在线观看一区二区少妇| CHINA篮球体育飞机2023| 美女脱三角裤| 24小时日本在线观看片免费| 久久亚洲伊人中字综合精品| 艳照门在线播放| 狠狠插狠狠干| 中国人泡妞www免费| 麻豆第一区MV免费观看网站| 97免费视频观看| 全彩黄漫火影忍者纲手无遮挡| 大香伊人久久| 天天射天天干天天插| 国产亚洲人成在线视频 | 亚洲.日韩.欧美另类| 亚洲精品动漫免费二区| 九九热视频免费| 99精品免费久久久久久久久日本 | 无码观看AAAAAAAA片| 国产精品人妻在线观看| 亚洲免费视频在线观看| 韩国电影real在线观看完整版 | 亚洲黄色在线| 久草在线精彩免费视频| 在线免费福利| 欧美在线看费视频在线| 国产精品欧美久久久久天天影视| 亚洲第一成年人网站| 久久精品中文字幕有码日本| 91久久偷偷做嫩草影院免费看| 欧美激情视频一区| 父皇轻点插好疼H限| 亚洲免费无l码中文在线视频| 久久99精品国产免费观看| 99热这里只就有精品22| 无限资源在线观看完整版免费下载| 精品久久香蕉国产线看观看麻豆| 5g在视影讯天天5g免费观看|