版權(quán)說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請進(jìn)行舉報(bào)或認(rèn)領(lǐng)
文檔簡介
1、西安郵電大學(xué)MATLAB及其EDA仿真課內(nèi)實(shí)驗(yàn)報(bào)告院(系)名稱:電子工程學(xué)院學(xué)生姓名:李豪專業(yè)名稱:集成電路設(shè)計(jì)與集成系統(tǒng) 班 級: 1202班時(shí) 間:2013年12月20日實(shí)驗(yàn)內(nèi)容建立基于圖形用戶界面GUI的學(xué)生成績管理系統(tǒng),該系統(tǒng)能夠?qū)崿F(xiàn)學(xué)生成績信息的增 加、刪除、查詢(查詢某門課所有學(xué)生的成績并顯示排名,查詢某個(gè)學(xué)生的各科成績并顯示排 名)、課程成績統(tǒng)計(jì)最高分、最低分、平均分、方差、并顯示相應(yīng)的排名;繪制柱狀圖、條形 圖、餅狀圖、正太分布曲線等功能。2、 實(shí)驗(yàn)?zāi)康耐ㄟ^本實(shí)驗(yàn)使學(xué)生掌握圖形用戶界面GUI的操作和設(shè)計(jì)流程,并通過編寫回調(diào)函數(shù)鞏 固前期的知識。3、 報(bào)告正文(-)設(shè)計(jì)思路菜單模
2、塊E0學(xué)生成績管'理系統(tǒng)界面J菜單模塊顯示模塊繪圖模塊統(tǒng) 計(jì) 成 績< A(二)設(shè)計(jì)步驟與設(shè)計(jì)內(nèi)容1 .啟動(dòng)GUI,命令窗口中輸入guide2 .放置控件。先放置一個(gè)EditText, tag名稱設(shè)為echt14,顏色設(shè)置為灰色,String設(shè)置為學(xué)生成績管理系統(tǒng)',該控件的功能是顯示該GUI的功能;再放置五個(gè)EcHtText, tag名稱分別設(shè)為ed汨、edit2x edit3、edit4v edit13,顏色均設(shè)置為 淡藍(lán)色,String分別設(shè)置為姓名'、學(xué)號'、成績其他'、排名'、'成績類型 ',這些控件的功能作為下面
3、listbox的標(biāo)題;再放置四個(gè)listbox,tag名稱分別設(shè) 為 xingming、xuehao grade paiming,顏色均設(shè)置淡藍(lán)色,String設(shè)置為'',這些 該控件的功能是分別顯示對應(yīng)學(xué)生的姓名、學(xué)號、成績、排名;再放置五個(gè)EditText, tag名稱分 別設(shè)為edit7、edit8X edit9、edit。、editll,顏色均設(shè)置為淡藍(lán)色,String分 別設(shè)置為專業(yè),數(shù)學(xué)英語,'體育物理,該控件的功能是顯示個(gè)人 對應(yīng)的科目;再放 置一個(gè)Axes, tag名稱設(shè)為axesl,顏色設(shè)置為灰色,該控件的功能 是顯示繪制的圖;3保存Jig文件4.編寫
4、.m文件,這部分要詳細(xì)敘述每個(gè)子函數(shù)的編寫思路,每條語句后面要給出注釋 說明 該語句的功能;只需要附上自己編寫的回調(diào)函數(shù)部分,其他系統(tǒng)自動(dòng)生成的不需 要放入報(bào) 告中。讀取數(shù)據(jù)思路:從表格中讀取數(shù)據(jù)的對應(yīng)行賦給對應(yīng)的句柄grade,form=xlsread("); %從 EXCEL 表格讀取數(shù)據(jù)=grade; %所有成績=grade(:,1);%專業(yè)課成績=grade(:,2); %英語成績=grade(:,3);%數(shù)學(xué)成績 i=grade(:,4); %體育成績=grade£5); %物理成績=form(2:end,1);%姓名=form(2:end,2);%學(xué)號%Choo
5、sedefaultcommandlineoutputforGUI=hObject;%Updatehandlesstructure guidata(hObject,handles); 顯示單科成績及對應(yīng)學(xué)生的姓名學(xué)號和排名思路:利用下拉菜單,獲取value值,用case語句判斷,當(dāng)選中下拉 菜單的某項(xiàng)時(shí),把該項(xiàng)對應(yīng)的成績,姓名,學(xué)號,排名的值送給對應(yīng)listbox 顯示。val=get(hObject, 'value'); %獲取下拉菜單控件的 value 值 switch val;case 2%選中下拉菜單的第二項(xiàng)set, ,String, %將選中的成績給set, '
6、String, %將選中的學(xué)生姓名給set, 'String, , %將選中的學(xué)生學(xué)號給=;%將選中的成績賦給一個(gè)變量guidata(hObject,handles); %更新句柄 major=;n=length(major); %獲取專業(yè)課成績數(shù)據(jù)長度 d=zeros(n,1);%創(chuàng)建一個(gè)n行一列的全零矩陣for i=1 :na,b=max(major);%獲取major的最大值和位置major(b,1)=0; %把major的最大值置換為0 d(b,1)=i;%矩陣d存儲成績的排名end=d; %把排名給一個(gè)新的變量set,'String',d); %使排名顯示ca
7、se 3set,'String', %將選中的成績給set,'String', %將選中的學(xué)生姓名給set,'String', %將選中的學(xué)生學(xué)號給=;%將選中的成績賦給一個(gè)變量english=;n=length(english);%獲取英語課成績數(shù)據(jù)長度d=zeros(n,1); %創(chuàng)建一個(gè)n行一列的全零矩陣 for i=1 :na,b=max(english);%獲取 english 的最大值和位置 english(b,1)=0;%把english 的最大值置換為0d(b,1)=i;%矩陣d存儲成績的排名end=d; %把排名給一個(gè)新的變量
8、set, 'String* ,d);case 4set, 'String'set, *String'set, 'String',%將選中的成績給,%將選中的學(xué)生姓名給,%將選中的學(xué)生學(xué)號給=;%將選中的成績賦給一個(gè)變量 math=;n=length(math);%獲取數(shù)學(xué)成績數(shù)據(jù)長度d=zeros(n,1); %創(chuàng)建一個(gè)n行一列的全零矩陣for i=1 :na,b=max(math); %獲取English的最大值和位置math(b,1)=0; %把math的最大值置換為0d(b,1)=i;%矩陣d存儲成績的排名end=d;set, 'S
9、tring' ,d);%顯示 math 成績排名 case 5set, 'String' set, 'String' set, 'String',%將選中的成績給,%將選中的學(xué)生姓名給,%將選中的學(xué)生學(xué)號給=;%將選中的成績賦給一個(gè)變量 physical;n=length(physical);%獲取物理成績數(shù)據(jù)長度d=zeros(n,1); %創(chuàng)建一個(gè)n行一列的全零矩陣 for i=1 :na,b=max(physical);%獲取 physical 的最大值和位置physical(b,1)=0; %把math的最大值置換為0d(b,1)
10、=i;%矩陣d存儲成績的排名end=d;set,'String',d); %顯示 physical成績排名case 6set,'String,%將選中的成績給set,'String',%將選中的學(xué)生姓名給set,String,%將選中的學(xué)生學(xué)號給=;%將選中的成績賦給一個(gè)變量physics=; n=length(physics);%獲取 physics 成績數(shù)據(jù)長度 %d=zeros(n,1); %創(chuàng)建一個(gè)n行一列的全零矩陣for i=1 :n a,b=max(physics);%獲取physics的最大值和位置physics(b,1)=0; %把phy
11、sics 的最大值置換為0 d(b,1)=i;%矩陣d存儲成績的排名end =d; %?§eu ? ± ?d?set, 'String' ,d);%顯示 physics 成績排名case 7:;在A中儲存各科成績grade=sum(A);%對各科成績求和sum_grade=grade,;% 轉(zhuǎn)置set, 'String' ,sum_grade)%顯示總成績set, 'String', %顯示姓名 set, 'String', %顯示學(xué)號 =sum_grade; %把總成績給一個(gè)變量 =sum_grade;% 給
12、總成績排名 n=length(sum_grade); %獲取總成績數(shù)據(jù)長度%d=zeros(n,1);%創(chuàng)建一個(gè)n行一列的全零矩陣for i=1 :na,b=max(sum_grade);%獲取總成績的最大值和位置%sum_grade(b,1)=0; %把總成績的最大值置換為0 d(b,1)=i;%矩陣d存儲總成績的排名end =d;set, 'String' ,d);%顯示總成績排名 end guidata(hObject,handles);統(tǒng)計(jì)分?jǐn)?shù)菜單模塊思路:利用下拉菜單,獲取value值,判斷value值,調(diào)用對應(yīng)的函數(shù)(求平均值、最大值、最小值、方差函數(shù))。val=g
13、et (hObject, Value');switch valcase 2x,y=max; %獲取當(dāng)前選中成績的最大值set, 'String',x);%顯示最高成績set, 'String*,(y);%顯示對應(yīng)的姓名set, 'String',(y);%顯示對應(yīng)的學(xué)號set, 'String1,);%不顯示排名case 3x,y=min;%獲取當(dāng)前選中成績的最大值set, 'String',x); %顯示最低成績set, 'String',(y);%顯示對應(yīng)的姓名set, 'String'
14、,(y);%顯示對應(yīng)的學(xué)號set, 'String1,);%不顯示排名case 4middle=mean;%獲取當(dāng)前選中成績的平均值set, 'String' ,middle) ;%顯示平均成績set,'String,);%不顯示姓名set,'String',);%不顯示學(xué)號set,'String',);%不顯示排名case 5Var=var; %獲取當(dāng)前選中成績的方差endset, 'String'set, 'String'set, 'String'set, 'String
15、',Var); %顯示方差 ,);%不顯示姓名 ,);%不顯示學(xué)號 ,);%不顯示排名功能菜單模塊(添加、刪除、查詢)添加思路:判斷數(shù)據(jù)的長度,將此長度記為n,然后在地n+1行寫入新 的數(shù)據(jù);刪除思路:用strcmp比較輸入學(xué)生的姓名和已有的姓名,用力nd函數(shù)記錄該比較的值,給需要?jiǎng)h除的學(xué)生信息賦為空值,即可實(shí)現(xiàn)刪除功幺匕目匕;查詢思路:用strcmp比較輸入學(xué)生的姓名和已有的姓名,記用find函數(shù)錄該比較的值,將查詢的學(xué)生信息顯示在listbox o繪圖菜單模塊思路:獲取下拉菜單的value,判斷value值,調(diào)用對應(yīng)的 繪圖函數(shù)(case2 hist;%繪制柱狀圖case3bar;
16、%繪制條形圖case4histfit,6) ;%繪制正太分布曲線case 5 pie;%繪制餅狀圖)5.運(yùn)行結(jié)果,包括GUI的初始化界面、查詢界面、刪除功能、統(tǒng)計(jì)功能等,可以用圖片 形式展現(xiàn);初始界面查詢界面刪除功能統(tǒng)計(jì)功能(三)問題與心得體會1總結(jié)實(shí)驗(yàn)中遇到的問題及解決方法;問題一:如何實(shí)現(xiàn)增加學(xué)生信息功能。解決方法:詢問老師(用length函數(shù)判斷數(shù)據(jù)的長度,在n+1行寫入新的信息)。問 題二:成績排名函數(shù)不能實(shí)現(xiàn)排名功能。解決方法:詢問老師(應(yīng)該把循環(huán)變量i賦給排名變量,而不是成績最大值的位置)問題三:怎樣實(shí)現(xiàn)查詢信息功能解決方法:詢問老師(用strcmp函數(shù)比較輸入的信息和已有信息,將結(jié)果給一個(gè)變 量i,用find函數(shù)尋找i=1的位置,將該位置學(xué)生的信息顯示出來即可實(shí)現(xiàn)查詢功能)問 題四:清空excel表格數(shù)據(jù)后寫入信息不能實(shí)現(xiàn)。解決方法:用help命令查詢xlswiite函數(shù)使用語法,可能因?yàn)閙atlab軟件版本的原 因 導(dǎo)致實(shí)驗(yàn)指導(dǎo)書上的xlswrite命令不能實(shí)現(xiàn),使用help查詢的xlswrite命令書寫個(gè)時(shí)候 實(shí)現(xiàn)想excel表格寫入信息。問題五:調(diào)用繪圖函數(shù)不能實(shí)現(xiàn)繪圖。解決方法:把坐標(biāo)設(shè)置為當(dāng)前坐標(biāo)。2學(xué)生成績管理系統(tǒng)的哪些功能沒有實(shí)現(xiàn);實(shí)現(xiàn)了所有的功能3撰寫進(jìn)
溫馨提示
- 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請下載最新的WinRAR軟件解壓。
- 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
- 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁內(nèi)容里面會有圖紙預(yù)覽,若沒有圖紙預(yù)覽就沒有圖紙。
- 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
- 5. 人人文庫網(wǎng)僅提供信息存儲空間,僅對用戶上傳內(nèi)容的表現(xiàn)方式做保護(hù)處理,對用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對任何下載內(nèi)容負(fù)責(zé)。
- 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請與我們聯(lián)系,我們立即糾正。
- 7. 本站不保證下載資源的準(zhǔn)確性、安全性和完整性, 同時(shí)也不承擔(dān)用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。
最新文檔
- 教師開學(xué)前軍訓(xùn)心得體會5篇
- 物流設(shè)施與設(shè)備第二章航空管道
- 債務(wù)償付質(zhì)押合同(2篇)
- 公共事業(yè)投資合作協(xié)議書(2篇)
- 河南省安陽市第六十二中學(xué)2022年高三語文下學(xué)期期末試卷含解析
- 2025年Γ-球蛋白三類項(xiàng)目合作計(jì)劃書
- 上海寫字樓租賃合同范本
- 幼兒園房屋租賃合同書范本
- 小吃街?jǐn)偽蛔赓U合同
- 長期租賃合同范本
- 【課件】第15課 中國古代陶瓷藝術(shù) 課件高中美術(shù)魯美版美術(shù)鑒賞
- 三年級上冊數(shù)學(xué)教案 - 6.2整理與提高(解決問題-燈市) 滬教版
- 東華醫(yī)院信息平臺解決方案-藥房流程接口
- 通力電梯KCE電氣系統(tǒng)學(xué)習(xí)指南
- 風(fēng)電場崗位任職資格考試題庫大全-下(填空題2-2)
- 九年級數(shù)學(xué)特長生選拔考試試題
- 幼兒園交通安全宣傳課件PPT
- 門窗施工組織設(shè)計(jì)與方案
- 健身健美(課堂PPT)
- (完整版)財(cái)務(wù)管理學(xué)課后習(xí)題答案-人大版
- 錨索試驗(yàn)總結(jié)(共11頁)
評論
0/150
提交評論