已阅读5页,还剩24页未读, 继续免费阅读
版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
Matlab入门教程-二维绘图 .基本xy平面绘图命令 MATLAB不但擅长於矩阵相关的数值运算,也适合用在各种科学目视表示 (Scientific visualization)。本节将介绍MATLAB基本xy平面及xyz空间 的各项绘图命令,包含一维曲线及二维曲面的绘制、列印及存档。 plot是绘制一维曲线的基本函数,但在使用此函数之前,我们需先定义曲 线上每一点的x及y座标。下例可画出一条正弦曲线: close all; x=linspace(0, 2*pi, 100); % 100个点的x座标 y=sin(x); % 对应的y座标 plot(x,y); = 小整理:MATLAB基本绘图函数 plot: x轴和y轴均为线性刻度(Linear scale) loglog: x轴和y轴均为对数刻度(Logarithmic scale) semilogx: x轴为对数刻度,y轴为线性刻度 semilogy: x轴为线性刻度,y轴为对数刻度 = 若要画出多条曲线,只需将座标对依次放入plot函数即可: plot(x, sin(x), x, cos(x); 若要改变颜色,在座标对後面加上相关字串即可: plot(x, sin(x), c, x, cos(x), g); 若要同时改变颜色及图线型态(Line style),也是在座标对後面加上相 关字串即可: plot(x, sin(x), co, x, cos(x), g*); = 小整理:plot绘图函数的叁数 字元 颜色 字元 图线型态 y 黄色 . 点 k 黑色 o 圆 w 白色 x x b 蓝色 + + g 绿色 * * r 红色 - 实线 c 亮青色 : 点线 m 锰紫色 -. 点虚线 - 虚线 = 图形完成後,我们可用axis(xmin,xmax,ymin,ymax)函数来调整图轴的范 围: axis(0, 6, -1.2, 1.2); 此外,MATLAB也可对图形加上各种注解与处理: xlabel(Input Value); % x轴注解 ylabel(Function Value); % y轴注解 title(Two Trigonometric Functions); % 图形标题 legend(y = sin(x),y = cos(x); % 图形注解 grid on; % 显示格线 我们可用subplot来同时画出数个小图形於同一个视窗之中: subplot(2,2,1); plot(x, sin(x); subplot(2,2,2); plot(x, cos(x); subplot(2,2,3); plot(x, sinh(x); subplot(2,2,4); plot(x, cosh(x); MATLAB还有其他各种二维绘图函数,以适合不同的应用,详见下表。 = 小整理:其他各种二维绘图函数 bar 长条图 errorbar 图形加上误差范围 fplot 较精确的函数图形 polar 极座标图 hist 累计图 rose 极座标累计图 stairs 阶梯图 stem 针状图 fill 实心图 feather 羽毛图 compass 罗盘图 quiver 向量场图 = 以下我们针对每个函数举例。 当资料点数量不多时,长条图是很适合的表示方式: close all; % 关闭所有的图形视窗 x=1:10; y=rand(size(x); bar(x,y); 如果已知资料的误差量,就可用errorbar来表示。下例以单位标准差来做 资料的误差量: x = linspace(0,2*pi,30); y = sin(x); e = std(y)*ones(size(x); errorbar(x,y,e) 对於变化剧烈的函数,可用fplot来进行较精确的绘图,会对剧烈变化处进 行较密集的取样,如下例: fplot(sin(1/x), 0.02 0.2); % 0.02 0.2是绘图范围 若要产生极座标图形,可用polar: theta=linspace(0, 2*pi); r=cos(4*theta); polar(theta, r); 对於大量的资料,我们可用hist来显示资料的分情况和统计特性。下面 几个命令可用来验证randn产生的高斯乱数分: x=randn(5000, 1); % 产生5000个 ?=0,?=1 的高斯乱数 hist(x,20); % 20代表长条的个数 rose和hist很接近,只不过是将资料大小视为角度,资料个数视为距离,?眉昊嬷票硎荆?x=randn(1000, 1); rose(x); stairs可画出阶梯图: x=linspace(0,10,50); y=sin(x).*exp(-x/3); stairs(x,y); stems可产生针状图,常被用来绘制数位讯号: x=linspace(0,10,50); y=sin(x).*exp(-x/3); stem(x,y); stairs将资料点视为多边行顶点,并将此多边行涂上颜色: x=linspace(0,10,50); y=sin(x).*exp(-x/3); fill(x,y,b); % b为蓝色 feather将每一个资料点视复数,并以箭号画出: theta=linspace(0, 2*pi, 20); z = cos(theta)+i*sin(theta); feather(z); compass和feather很接近,只是每个箭号的起点都在圆点: theta=linspace(0, 2*pi, 20); z = cos(theta)+i*sin(theta); compass(z); 3.基本XYZ立体绘图命令 在科学目视表示(Scientific visualization)中,三度空间的立体图是 一个非常重要的技巧。本章将介绍MATLAB基本XYZ三度空间的各项绘图命 令。 mesh和plot是三度空间立体绘图的基本命令,mesh可画出立体网状图, plot则可画出立体曲面图,两者产生的图形都会依高度而有不同颜色。下 列命令可画出由函数 形成的立体网状图: x=linspace(-2, 2, 25); % 在x轴上取25点 y=linspace(-2, 2, 25); % 在y轴上取25点 xx,yy=meshgrid(x, y); % xx和yy都是21x21的矩阵 zz=xx.*exp(-xx.2-yy.2); % 计算函数值,zz也是21x21的矩阵 mesh(xx, yy, zz); % 画出立体网状图 surf和mesh的用法类似: x=linspace(-2, 2, 25); % 在x轴上取25点 y=linspace(-2, 2, 25); % 在y轴上取25点 xx,yy=meshgrid(x, y); % xx和yy都是21x21的矩阵 zz=xx.*exp(-xx.2-yy.2); % 计算函数值,zz也是21x21的矩阵 surf(xx, yy, zz); % 画出立体曲面图 为了方便测试立体绘图,MATLAB提供了一个peaks函数,可产生一个凹凸有 致的曲面,包含了三个局部极大点及三个局部极小点,其方程式为: 要画出此函数的最快方法即是直接键入peaks: peaks z = 3*(1-x).2.*exp(-(x.2) - (y+1).2) . - 10*(x/5 - x.3 - y.5).*exp(-x.2-y.2) . - 1/3*exp(-(x+1).2 - y.2) 我们亦可对peaks函数取点,再以各种不同方法进行绘图。meshz可将曲面 加上围裙: x,y,z=peaks; meshz(x,y,z); axis(-inf inf -inf inf -inf inf); waterfall可在x方向或y方向产生水流效果: x,y,z=peaks; waterfall(x,y,z); axis(-inf inf -inf inf -inf inf); 下列命令产生在y方向的水流效果: x,y,z=peaks; waterfall(x,y,z); axis(-inf inf -inf inf -inf inf); meshc同时画出网状图与等高线: x,y,z=peaks; meshc(x,y,z); axis(-inf inf -inf inf -inf inf); surfc同时画出曲面图与等高线: x,y,z=peaks; surfc(x,y,z); axis(-inf inf -inf inf -inf inf); contour3画出曲面在三度空间中的等高线: contour3(peaks, 20); axis(-inf inf -inf inf -inf inf); contour画出曲面等高线在XY平面的投影: contour(peaks, 20); plot3可画出三度空间中的曲线: t=linspace(0,20*pi, 501); plot3(t.*sin(t), t.*cos(t), t); 亦可同时画出两条三度空间中的曲线: t=linspace(0, 10*pi, 501); plot3(t.*sin(t), t.*cos(t), t, t.*sin(t), t.*cos(t), -t); MATLAB 程式设计与应用 1-1、基本运算与函数 在MATLAB下进行基本数学运算,只需将运算式直接打入提示号()之後,并按入Enter键即可。例如: (5*2+1.3-0.8)*10/25 ans = 4.2000 MATLAB会将运算结果直接存入一变数ans,代表MATLAB运算後的答案 (Answer),并显示其数值於萤幕上。(为简便起见,在下述各例中,我 们不再印出MATLAB的提示号。) = 小提示: 是MATLAB的提示符号(Prompt),但在PC中文视窗系统下,由於编码方式不同,此提示符号常会消失不见,但这并不会影响到MATLAB的运算结果。 = 我们也可将上述运算式的结果设定给另一个变数x: x = (5*2+1.3-0.8)*102/25 x = 42 此时MATLAB会直接显示x的值。由上例可知,MATLAB认识所有一般常用到的 加(+)、减(-)、乘(*)、除(/)的数学运算符号,以及幂次运算 ()。 小提示: MATLAB将所有变数均存成double的形式,所以不需经过变数宣告(Variable declaration)。MATLAB同时也会自动进行记忆体的使用和回收,而不必像C语言,必须由使用者一一指定。这些功能使的MATLAB易学易用,使用者可专心致力於撰写程式,而不必被软体枝节问题所干扰。 若不想让MATLAB每次都显示运算结果,只需在运算式最後加上分号(;) 即可,如下例: y = sin(10)*exp(-0.3*42); 若要显示变数y的值,直接键入y即可: y y = -0.0045 在上例中,sin是正弦函数,exp是指数函数,这些都是MATLAB常用到的数 学函数。下表即为MATLAB常用的基本数学函数及三角函数: = 小整理:MATLAB常用的基本数学函数 abs(x):纯量的绝对值或向量的长度 angle(z):复数z的相角(Phase angle) sqrt(x):开平方 real(z):复数z的实部 imag(z):复数z的虚部 conj(z):复数z的共轭复数 round(x):四舍五入至最近整数 fix(x):无论正负,舍去小数至最近整数 floor(x):地板函数,即舍去正小数至最近整数 ceil(x):天花板函数,即加入正小数至最近整数 rat(x):将实数x化为分数表示 rats(x):将实数x化为多项分数展开 sign(x):符号函数 (Signum function)。 当x0时,sign(x)=1。 rem(x,y):求x除以y的馀数 gcd(x,y):整数x和y的最大公因数 lcm(x,y):整数x和y的最小公倍数 exp(x):自然指数 pow2(x):2的指数 log(x):以e为底的对数,即自然对数或 log2(x):以2为底的对数 log10(x):以10为底的对数 = 小整理:MATLAB常用的三角函数 sin(x):正弦函数 cos(x):馀弦函数 tan(x):正切函数 asin(x):反正弦函数 acos(x):反馀弦函数 atan(x):反正切函数 atan2(x,y):四象限的反正切函数 sinh(x):超越正弦函数 cosh(x):超越馀弦函数 tanh(x):超越正切函数 asinh(x):反超越正弦函数 acosh(x):反超越馀弦函数 atanh(x):反超越正切函数 = 变数也可用来存放向量或矩阵,并进行各种运算,如下例的列向量(Row vector)运算: x = 1 3 5 2; y = 2*x+1 y = 3 7 11 5 = 小提示:变数命名的规则 1.第一个字母必须是英文字母 2.字母间不可留空格 3.最多只能有19个字母,MATLAB会忽略多馀字母 = 我们可以随意更改、增加或删除向量的元素: y(3) = 2 % 更改第三个元素 y = 3 7 2 5 y(6) = 10 % 加入第六个元素 y = 3 7 2 5 0 10 y(4) = % 删除第四个元素, y = 3 7 2 0 10 在上例中,MATLAB会忽略所有在百分比符号(%)之後的文字,因此百分比之後的文字均可视为程式的注解(Comments)。MATLAB亦可取出向量的一个元素或一部份来做运算: x(2)*3+y(4) % 取出x的第二个元素和y的第四个元素来做运算 ans = 9 y(2:4)-1 % 取出y的第二至第四个元素来做运算 ans = 6 1 -1 在上例中,2:4代表一个由2、3、4组成的向量,同样的方法可用於产生公 差为1的等差数列: x = 7:16 x = 7 8 9 10 11 12 13 14 15 16 若不希望公差为1,则可将所需公差直接至於4与13之间: x = 7:3:16 % 公差为3的等差数列 x = 7 10 13 16 事实上,我们可利用linspace来产生任意的等差数列: x = linspace(4, 10, 6) % 等差数列:首项为4,末项为10,项数为6 x = 4.0000 5.2000 6.4000 7.6000 8.8000 10.0000 若对MATLAB函数用法有疑问,可随时使用help来寻求线上支援(on-line help): help linspace LINSPACE Linearly spaced vector. LINSPACE(x1, x2) generates a row vector of 100 linearly equally spaced points between x1 and x2. LINSPACE(x1, x2, N) generates N points between x1 and x2. equally spaced points between x1 and x2. LINSPACE(x1, x2, N) generates N points between x1 and x2. See also LOGSPACE, :.matlab中遗传算法的一些例子!作者:未知文章来源:本站原创点击数: 401更新时间:2005-5-26下面是关于简单遗传算法和简单bp网络的程序给大家看一下。 看你有用否?y=1/x: %N=input(设定隐含层神经元个数:n); %maxecho=input(最大训练回合数); %网络初始化 N=3;%可以自己设定 maxecho=1000; h=0.4;%学习速率 p=1:1:100; t=1./p; inw=randn(N,2);%输入-隐含权值矩阵,单输入并加上了偏置一列 ins=zeros(N,1);%隐含得到的诱导矩阵 outg=zeros(N,1);%反向传到回至输入的delta值 outs=zeros(N,1);%隐含输出的矩阵 outw=randn(1,N+1);%隐含输出权值矩阵(加上一个偏置) outv=zeros(1,1);%输出得到的诱导矩阵 outy=zeros(1,1); backg=zeros(1,1);%反向传至隐含层的delta值 m=1; n=0; %开始样本训练 %for x=1:maxecho while(n0.2) m=0; for i=1:length(p) ins=inw*p(i);1; outs=1./(1+exp(-ins); outv=outw*outs;1; outy=1./(1+exp(-outv); backg=(t(i)-outy)*(outy.*(1-outy); outg=(outs.*(1-outs).*(outw(:,1:N)*backg); outw=outw+h*backg*outs;1; inw=inw+h*outg*p(i),1; m=m+(t(i)-outy)2; end n=n+1; end %开始样本测试 textp=1:0.1:100; textt=1./textp; textout=zeros(1,length(textp); error=zeros(1,length(textp); for i=1:length(textp) ins=inw*textp(i);1; outs=1./(1+exp(-ins); outv=outw*outs;1; outy=1./(1+exp(-outv); textout(i)=outy; error(i)=abs(textt(i)-textout(i); end %测试完成后,观察输出,以及误差的变化 k=1:0.1:100; plot(k,textt,r,k,textout,b,k,error,g); xlabel(n); 可以比较清楚的看到一个基本bp算法的过程,当时自己比较得意的就是其中的矩阵相乘。速度很快,而且比较容易扩展,即任意多的输入,任意多的隐含层。 到后来,我的人工智能老师(海龟,他的老师的老师就是乍得)要求比较综合的算法,然后半个月里没日没夜的作小的project,小小的一门人工智能课占据了几乎所有的课外时间,弄得随机过程差点没混过去。还记得圣诞节快乐的一天,那时候在老师家里聚会(project完成后),半夜里就下雪了。杭州很少下雪._,美妙的回忆。在做小程序期间认识了高手冰彬鱼六代(南航毕业,很强的人,自编了一个sga工具箱,现在法国留学),还有动力论坛的海阔天空,当时真是景仰万分,他们所作的无人能够代替。在此呢,略微效仿一下啦,虽然不算什么,但我是新手啊。ga优化神经网权值&阈值程序。 优化的基本原理和过程很多论文可以查到,在此不必赘述我就把用gaot5的小程序贴在下面吧,也是y=1/x(为看的方便,比较繁杂的也有) file:gabp.m %* clear all % 用GA训练BP网络的权值、阈值 % 开始计时 tic, % BP网络初始化 P,T,R,S1,S2,S=bpinit; bounds=ones(S,1)*-10 10; % 初始种群个数 num=60; pop=initializega(num,bounds,fitness); % % clear all % % 用GA训练BP网络的权值、阈值 % % 开始计时 % tic, % % BP网络初始化 % P,T,R,S1,S2,S=bpinit; % bounds=ones(S,1)*0.1 0.9; % % 初始种群个数 % num=60; % pop=initializega(num,bounds,fitness); % % 遗传代数 % % 遗传代数 gen=500; x endPop bPop trace=ga(bounds,fitness,pop,1e-6 1 1,maxGenTerm,gen,. normGeomSelect,0.09,arithXover,2,nonUnifMutation,2 gen 3); for i=1:S x(i)=endPop(1,i); end; sum=0; % 前R*S1个编码为W1 for i=1:S1, for k=1:R, W1(i,k)=x(R*(i-1)+k); end end % 接着的S1*S2个编码(即第R*S1个后的编码)为W2 for i=1:S2, for k=1:S1, W2(i,k)=x(S1*(i-1)+k+R*S1); end end % 接着的S1个编码(即第R*S1+S1*S2个后的编码)为B1 for i=1:S1, B1(i,1)=x(R*S1+S1*S2)+i); end % 接着的S2个编码(即第R*S1+S1*S2+S1个后的编码)为B2 for i=1:S2, B2(i,1)=x(R*S1+S1*S2+S1)+i); end % 计算S1与S2层的输出 for i=1:100 x1=W1*P(i)+B1; A1=1./(1+exp(-x1); x2=W2*A1+B2; A2=1./(1+exp(-x2); % A1=logsig(W1*P(1:17,i),B1); % A2=logsig(W2*A1,B2); YY(i)=A2; % 计算误差平方和 % SE=; %sum=sum+sumsqr(T(i)-A2); end i=1:1:100 plot(i,YY(i),r+,i,T(i),b-); % W1 B1 W2 B2=gadecod(x); % 仿真结果 % TT=simuff(P,W1,B1,logsig,W2,B2,logsig) toc % 结束计时 file:fitness.m functionsol,eval=fitness(sol,options) P,T,R,S1,S2,S=bpinit; numv=size(sol,2)-1; x=sol(1:numv); eval=f(x); file:f.m function eval=f(sol) numv=size(sol,2); x=sol(1:numv); P,T,R,S1,S2,S=bpinit; %get the value of fitness % 前R*S1个编码为W1 for i=1:S1 for k=1:R, W1(i,k)=x(R*(i-1)+k); end end % 接着的S1*S2个编码(即第R*S1个后的编码)为W2 for i=1:S2 for k=1:S1, W2(i,k)=x(S1*(i-1)+k+R*S1); end end % 接着的S1个编码(即第R*S1+S1*S2个后的编码)为B1 for i=1:S1 B1(i,1)=x(R*S1+S1*S2)+i); end % 接着的S2个编码(即第R*S1+S1*S2+S1个后的编码)为B2 for i=1:S2 B2(i,1)=x(R*S1+S1*S2+S1)+i); end sum=0; SE=0; for i=1:100 x1=W1*P(i)+B1; A1=1./(1+exp(-x1); x2=W2*A1+B2; A2=1./(1+exp(-x2); % A1=logsig(W1*P(1:17,i),B1); % A2=logsig(W2*A1,B2); % 计算误差平方和 SE=sumsqr(T(i)-A2); sum=sum+SE; end eval=10/sum; % 遗传算法的适应值 file:bpinit.m % BP网络初始化:给出网络的训练样本P、T, % 输入、输出数及隐含神经元数R,S2,S1 function P,T,R,S1,S2,S=bpinit; for i=1:100 P(i)=i; T(i)=1/P(i); end R,Q=size(P);%R=1 S2,Q=size(T);%S2=1 S1=3;%3 nu S=R*S1+S1*S2+S1+S2; % 遗传算法编码长度。这个是copy的。 这里做了一个所谓的军费预测(没题目找啊) file:xw_ga_ann_19%431网络,总共19个权值阈值 clear all; clc; format long; Population_Size=200; String_Length=190; chromosome=round(rand(Population_Size,String_Length); chromosome_change=zeros(Population_Size,String_Length); flag=1; fitness_function=zeros(1,Population_Size); selected=zeros(1,Population_Size); generation=1; maxsat=0; a1=zeros(3,5,10); a2=zeros(1,4,10); param1=zeros(3,5); param2=zeros(1,4); x_param1=zeros(3,5); y_param2=zeros(1,4); while(flag0)&(generationmaxsat) maxsat=fitness_function(1,i); optimal_1=x_param1; optimal_2=y_param2; optimal_3=fitness_function(1,i); end if(fitness_function(1,i)=0.001) flag=-1; %optimal %generation break; else sum_fit=sum_fit+fitness_function(1,i); end if(flag0) %the first select sum_fit=sum_fit-fitness_function(1,Population_Size); for i=1:Population_Size-1 x=round(randn(1)*1023); sum=round(sum_fit); rr=rem(x,sum); n=1;ba=1; partsum=0; while(partsumrr)&(nPopulation_Size-1) parsum=partsum+fitness_function(1,n); ba=n; n=n+1; end selected(1,i)=ba; end %reproduce for i=1:Population_Size-1 for j=1:String_Length chromosome_change(i,j)=chromosome(selected(1,i),j); end fitness_function(1,i)=fitness_function(1,selected(1,i); end %select before crossover for i=1:Population_Size-1 x=round(rand(1)*32367); sum=round(sum_fit); rr=rem(x,sum)+1; n=1; partsum=0; while(partsumrr)&(n=Population_Size-1) partsum=partsum+fitness_function(1,n); bba=n; n=n+1; end selected(1,i)=bba; end %crossover maxsw=max(fitness_function); for i=1:Population_Size/2-1 parent1=selected(1,i); parent2=selected(1,Population_Size-1-i); child1=i; child2=Population_Size-1-i; pc=0.8; randnum=rand(1); if randnumpc site1=round(rand(1)*String_Length); for j=1:String_Length if(jsite1) chromosome(child1,j)=chromosome_change(parent1,j); chromosome(child2,j)=chromosome_change(parent2,j); else chromosome(child1,j)=chromosome_change(parent2,j); chromosome(child2,j)=chromosome_change(parent1,j); end end end end %mutation pm=0.1; for i=1:Population_Size-1 for j=1:String_Length randnum=rand(1); if(randnumpm) chromosome(i,j)=chromosome(i,j);%变异取反 %else % chromosome(i,j)=chromosome(i,j);%变异取反 end end end end generation=generation+1; end %* %ANN start sensorN=3;%神经元数 stopR=50000;%训练停止回合数 h=1;%学习率 %-% %trainS=1:1:100; %trainD=1./trainS;%训练样本 trainS=1988 1989 1990 1991 1992 1993 1994 1995 1996 1997 1998 1999 2000 2001 2002 2003 ; maxp=max(trainS); minp=min(trainS); for i=1:16 trainS(i)=(trainS(i)-minp)/(maxp-minp)*0.9+0.05; end trainD=293093 304085 306170 280292 305141 297637 288059 278856 271417 276324 274278 280969 301697 312743 356720 446320; maxt=max(trainD); mint=min(trainD); for i=1:16 trainD(i)=(trainD(i)-mint)/(maxt-mint)*0.9+0.05; end %trainS=1:1:100; %trainD=1./trainS;%训练样本 HLW=randn(sensorN,5);%隐含层权值 %HLW=x1,x2; x3,x4; x5,x6; HLW=optimal_1; HLV=zeros(sensorN,1);%隐含层诱导局部域 HLOut=zeros(sensorN,1);%隐含层
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 2025年全国导游基础知识题库及答案
- 2025年教师资格证考试题库及答案
- 2025年夏季安全施工试题及答案
- 视频广告创意优化策略-洞察与解读
- 会计证考试题型及答案
- 会计继续教育考试试题及答案
- (2025年)第一部分导游知识测试题库附有答案
- 黄冈教师面试题目及答案
- 安全生产法宣传培训课件
- 鸡粪资源化的经济效益与环境效益分析
- 水利工程灾情评估者2025洪水灾害预测与防治方案
- 甘肃省兰州市第五中学2024-2025学年七年级上学期期中考试数学试卷(含答案)
- GB/T 20805-2025饲料中酸性洗涤木质素(ADL)的测定
- 2025年法学专业基础知识考试试题及答案
- 折叠技术基础知识培训课件
- 2025至2030中国自然教育行业项目调研及市场前景预测评估报告
- 2025年入团考试题库及答案
- T-CCA 037-2025 老年人膳食设计与烹饪技术规范
- 国企印章管理办法
- 基于卷积神经网络的水果识别系统的设计与实现
- 自家房屋管理办法
评论
0/150
提交评论