国产日韩欧美一区二区三区三州_亚洲少妇熟女av_久久久久亚洲av国产精品_波多野结衣网站一区二区_亚洲欧美色片在线91_国产亚洲精品精品国产优播av_日本一区二区三区波多野结衣 _久久国产av不卡

?

基于Python的車燈動畫效果數(shù)據(jù)化技術(shù)

2022-08-03 06:51孫瑜
汽車零部件 2022年7期
關(guān)鍵詞:數(shù)據(jù)表賦值時序

孫瑜

常州星宇車燈股份有限公司,江蘇常州 213000

0 引言

LED憑借著亮度高、顏色飽和度高、低功耗、壽命長的特點逐漸取代鹵素?zé)舫蔀檐嚐粜袠I(yè)的主流。同時隨著車燈開始朝著智能化、個性化和人性化的方向發(fā)展,車燈上LED使用數(shù)量越來越多,對LED的控制要求也越來越高,這也無疑增加了軟件的工作量以及工作難度。因此,本文設(shè)計了一種基于Python的車燈動畫效果數(shù)據(jù)化技術(shù),結(jié)合Excel及Python的特點,將車燈動畫效果數(shù)據(jù)化。從而實現(xiàn)車燈效果可視化配置以及快速修改更新,大大減小了軟件的工作量以及工作難度,適用于以后更加設(shè)計復(fù)雜、難度更高的LED車燈項目。

1 Excel動畫效果時序圖設(shè)計

1.1 燈組分布簡圖制作

根據(jù)結(jié)構(gòu)設(shè)計將燈組簡圖通過Excel進行繪制,并進行編號。圖1為燈組分布簡圖。

圖1 燈組分布簡圖

如圖1所示,灰色部分為后組合1燈組,黑色為后組合燈2燈組,淺灰色為后組合2的側(cè)標部分。其中,1~36號燈組只需要點亮熄滅功能,37~51號燈組帶呼吸效果,因此需要使用PWM進行控制。本文示例后組合燈共包含51組LED燈,將詳細呈現(xiàn)該后組合燈動畫效果數(shù)據(jù)化的過程。

1.2 動畫效果時序圖制作

動畫效果時序圖如圖2所示,按照燈組分布簡圖編號制作動畫效果時序圖,縱坐標為燈組編號及燈名,橫坐標為下一幀動畫的時間。圖中數(shù)字0表示燈組關(guān)燈,100表示完全點亮,1~99則用于需要控制燈組。此外可附上不同的顏色用于更直觀體現(xiàn)開關(guān)燈效果,使用顏色深淺表示值。此方案燈名命名規(guī)則如圖3所示。

圖2 動畫效果時序圖

圖3 燈名命名規(guī)則

圖3中,字符為燈具功能名稱(此方案為位置燈,故命名為tail),數(shù)字1為該燈組所在后組合燈位置(后組合燈1用數(shù)字1表示,后組合2用數(shù)字2表示),數(shù)字2為該燈組所在IC驅(qū)動地址,處于相同IC地址使用同一數(shù)字表示,數(shù)字3在32位數(shù)據(jù)類型無法滿足數(shù)據(jù)存儲時進行補充。

2 Excel動畫效果時序表參數(shù)導(dǎo)入

Jupyter Notebook是基于網(wǎng)頁的用于交互計算的應(yīng)用程序,可被應(yīng)用于全過程計算,包括開發(fā)、文檔編寫、運行代碼和展示結(jié)果等。Jupyter Notebook是以網(wǎng)頁的形式打開,可以在網(wǎng)頁頁面中直接編寫代碼和運行代碼,代碼的運行結(jié)果也會直接在代碼塊下顯示。如在編程過程中需要編寫說明文檔,可在同一個頁面中直接編寫,便于作及時的說明和解釋。

文中將通過Jupyter Notebook工具演示車燈動畫效果數(shù)據(jù)化過程。

如圖4所示,首先調(diào)用Openpyxl庫和NumPy庫,再通過Openpyxl庫導(dǎo)入Excel中數(shù)據(jù)存儲于Js_sheet中。

圖4 庫導(dǎo)入

之后通過Np.dtype定義數(shù)據(jù)類型,即Open_Type表示后組合燈動畫效果類型;Tail2_Type表示后組合燈2動畫效果類型;Tail1_Type表示后組合燈1動畫效果類型。其中“Name”為數(shù)據(jù)名,“Formates”為對應(yīng)數(shù)據(jù)類型。燈組1~36號只有開關(guān)狀態(tài),故每個燈組使用0.125 B;37~51號燈組為控制,故每個燈組需要0.875 B。數(shù)據(jù)“Time”表示下一幀動畫開始時間。初始化配置如圖5所示。

圖5 初始化配置

根據(jù)Excel中動畫效果時序圖,設(shè)置動畫效果總幀數(shù)(Frames_number),時間軸所在行(Time_row),動畫效果起始行(Time_start_col)以及每個數(shù)據(jù)起始行及行數(shù)。并通過Np.array創(chuàng)建后組合燈動畫效果矩陣(Open_Data),填充值為0。如下所示:

Open_Data=np.array([0]*frames_number,dtype=Open_Type)

3 動畫效果數(shù)據(jù)處理

按照數(shù)據(jù)名及數(shù)據(jù)類型定義各個數(shù)據(jù)緩存值并初始化,如圖6所示。

圖6 緩存數(shù)據(jù)初始化

利用For語句遍歷每幀動畫效果,同時將數(shù)據(jù)賦值相應(yīng)數(shù)據(jù)中。

(1)“Time”值可以直接讀取Js_sheet中第Time_row行數(shù)值。

Open_Data[i][’time’]=js_sheet.cell(time_row,time_start_col+i).value

(2)燈組1~36號通過判斷讀取值是否為0,根據(jù)燈組在該數(shù)據(jù)中位號進行賦值并做相應(yīng)位移。例如Tail21賦值方式如下:

#tail21數(shù)據(jù)獲取

for j in range(tail21_row_number):

if js_sheet.cell(tail21_row_start+j,time_start_col+i).value==0:

u16Tail21=u16Tail21&(~(0x01<

else:

u16Tail21=u16Tail21|(0x01<

Open_Data[i][tail21]=u16Tail21

(3)燈組37~51號直接將讀取數(shù)據(jù)賦值,因值占0.875 B,為方便讀取故每次讀取之后位移8位。例如Tail51賦值方式如下:

#tail151數(shù)據(jù)獲取

for j in range(tail151_row_number):

u8value=js_sheet.cell(tail151_row_seq[j],time_start_col+i).value

if u8value<=100:

u32Tail151=u32Tail151&(~(0xff<<(j*8)))

u32Tail151=u32Tail151|(u8value<<(j*8))

Open_Data[i][tail151]=u32Tail151

按照上述步驟,即可將Excel中數(shù)據(jù)全部導(dǎo)入Open_Data矩陣中。

4 動畫效果數(shù)據(jù)表生成

動畫效果數(shù)據(jù)表生成步驟為:

(1)定義后組合燈1(Tail1_Data)和后組合燈2(Tail2_Data)數(shù)據(jù)矩陣以及用于存放后組合1和后組合2的重復(fù)數(shù)據(jù)的數(shù)組(list_tail1_del,list_tail2_del)。

Tail1_Data=np.array([0]*frames_number,dtype=Tail1_Type)

Tail2_Data=np.array([0]*frames_number,dtype=Tail2_Type)

list_tail2_del=[]

list_tail1_del=[]

(2)從Open_Data數(shù)據(jù)矩陣中后組合1和后組合2數(shù)據(jù)分別存儲在Tail1_Data和Tail2_Data中。

(3)通過遍歷方式將Tail1_Data和Tail2_Data中重復(fù)數(shù)組序號分別存放在list_tail1_del和list_tail2_del中。

(4)刪除Tail1_Data和Tail2_Data重復(fù)數(shù)組,生成后組合燈1最終數(shù)據(jù)矩陣(Tail1)和后組合燈2最終數(shù)據(jù)矩陣(Tail1)。

Tail2=np.delete(Tail2_Data,list_tail2_del,0)

Tail1=np.delete(Tail1_Data,list_tail1_del,0)

(5)將最終生成的動畫效果數(shù)據(jù)打印出,并將燈組數(shù)據(jù)轉(zhuǎn)換為十六進制便于燈具軟件調(diào)用生成數(shù)據(jù)表。

后組合2動畫效果數(shù)據(jù)打印方式如下:

tail2_num=Tail2.size

print(’尾二動畫數(shù)據(jù)量:%i%tail2_num)

print(*************尾二動畫數(shù)據(jù)表*************)

for cell in Tail2:

print({%i%(cell[time]-offset_time),end=,)

print(0x%04x%cell[tail21],end=,)

print(0x%02x%cell[tail22],end=,)

print(0x%08x%cell[tail231],end=,)

print(0x%02x%cell[tail232],end=)

print(},)

后組合1動畫效果數(shù)據(jù)打印方式如下:

tail1_num=Tail1.size

print(尾一動畫數(shù)據(jù)量:%i%tail1_num)

print(*************尾一動畫數(shù)據(jù)表*************)

for cell in Tail1:

print({%i%(cell[time]-offset_time),end=,)

print(0x%02x%cell[tail11],end=,)

print(0x%02x%cell[tail12],end=,)

print(0x%02x%cell[tail13],end=,)

print(0x%02x%cell[tail14],end=,)

print(0x%08x%cell[tail151],end=,)

print(0x%08x%cell[tail152],end=,)

print(0x%04x%cell[tail153],end=)

print(},)

最終生成動畫效果數(shù)據(jù)表如圖7和圖8所示。

圖7 后組合2動畫效果數(shù)據(jù)表

圖8 后組合1動畫效果數(shù)據(jù)表

將生成數(shù)據(jù)導(dǎo)入相應(yīng)燈具軟件之中,并根據(jù)Tail1和Tail2數(shù)據(jù)類型編寫對應(yīng)解析代碼,即可直接使用動畫效果數(shù)據(jù)表。

5 結(jié)束語

本文基于Python和Excel設(shè)計了一種可以將車燈動畫效果數(shù)據(jù)化的技術(shù),利用Excel可以更加直觀地設(shè)計修改動畫效果,之后生成的數(shù)據(jù)也能確保正確性和有效性。后期動畫效果更新或者維護,僅需調(diào)整Excel中動畫效果圖以及相應(yīng)配置參數(shù),即可實時生成最新動畫效果參數(shù)表,直接導(dǎo)入燈具軟件中編譯即可,這大大節(jié)省軟件工程師的工作量及項目時間。對于目前越來越復(fù)雜的LED車燈設(shè)計,該技術(shù)也有極大的優(yōu)勢。該技術(shù)方案已應(yīng)用于實際車燈項目,測試及使用表現(xiàn)良好,表明了該設(shè)計具有實用性和可靠性。

猜你喜歡
數(shù)據(jù)表賦值時序
顧及多種弛豫模型的GNSS坐標時序分析軟件GTSA
清明
基于GEE平臺與Sentinel-NDVI時序數(shù)據(jù)江漢平原種植模式提取
你不能把整個春天都搬到冬天來
湖北省新冠肺炎疫情數(shù)據(jù)表(2.26-3.25)
湖北省新冠肺炎疫情數(shù)據(jù)表
湖北省新冠肺炎疫情數(shù)據(jù)表
算法框圖問題中的易錯點
抽象函數(shù)難度降 巧用賦值來幫忙
利用賦值法解決抽象函數(shù)相關(guān)問題オ