24小时热门版块排行榜    

查看: 675  |  回复: 5
当前只显示满足指定条件的回帖,点击这里查看本话题的所有回帖

btliu

金虫 (小有名气)

[求助] Matlab

如下表,希望通过循环数和步数的控制,通过设置电压(第二列)的误差,实现数据的挑选。如果不加循环和步数项,下面code可以实现单步工作,但是,增加了循环(n)和步数(m)后,就不工作了。 另外,还有一些小问题(见code标注),如:如果小数点后的位数很多时,似乎zx(find(zx==0))=[]; zy(find(zy==0))=[]; NewArray=[zx,zy]存在问题。急求高手指导!谢谢!

y = data(:,2); %对应y值
u = data(:,3); %对应步数
v = data(:,4); %对应循环数

zx =zeros(length(x),1);
zy =zeros(length(y),1);
h = 1;  
zx(1) = x(1);%保留第一步的数据(如何实现保留其他步的第一数据?)
zy(1) = y(1);

a=[10,1,0.1];
B=[0,(-0.1)*a(1),(-1)*a(1),0.1*a(1),1*a(1),(-0.1)*a(2),(-1)*a(2),0.1*a(2),1*a(2),(-0.1)*a(3),(-1)*a(3),0.1*a(3),1*a(3)];%B内部数的个数与步数对应
A=B*0.02;

for k = 2:length(x)
for n=1:max(v);
    for m=2:max(u);
        if  abs(y(k)-y(k-1))>=abs(A(m)); %现在好像A(2)等同时影响其他步的误差?)
        h = h+1;
        zx(h) = x(k-1);
        zy(h) = y(k-1);
        end
end
end     
end
zx(find(zx==0))=[];
zy(find(zy==0))=[];
NewArray=[zx,zy];
disp(NewArray);
plot(zx,zy,zx,zy,'o');
时间        电压        步数        循环数
5.008124936        -6.0395E-05        1        1
10.00032039        0.499913335        2        1
30.01483456        0.500076175        2        1
…        …        …        …
…        …        …        …
310.0146066        0.500076175        2        1
310.0304182        5.000491142        3        1
…        …        …        …
…        …        …        …
610.0291657        5.000491142        3        1
610.0294107        -0.49970841        4        1
630.0439261        -0.49987125        4        1
…        …        …        …
…        …        …        …
890.2321767        -0.49987125        4        1
910.0436822        -0.49987125        4        1
910.059488        0.499913335        2        2
930.0738865        0.500076175        2        2
…        …        …        …
…        …        …        …
1170.247626        0.499913335        2        2
1190.262159        0.500076175        2        2
1210.073952        0.499913335        2        2
1210.074271        5.000654221        3        2
…        …        …        …
…        …        …        …
1490.276902        5.000491142        3        2
1510.088659        5.000654221        3        2
1510.088878        -0.49954554        4        2
1530.103367        -0.49987125        4        2
…        …        …        …
…        …        …        …
1770.277052        -0.49987125        4        2
1790.291507        -0.49987125        4        2
1810.103251        -0.49987125        4        2
1810.119112        0.499750465        2        3
1830.133624        0.500076175        2        3
…        …        …        …
2090.321718        0.500076175        2        3
2110.133399        0.500076175        2        3
…        …        …        …
回复此楼

» 猜你喜欢

已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

realghost828

金虫 (小有名气)

【答案】应助回帖

感谢参与,应助指数 +1
括号不匹配。应该是第7行第12行多了半边括号或是少了半边括号了
人生就是要辉煌!
5楼2012-12-10 21:46:56
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖
查看全部 6 个回答

风泊

铁杆木虫 (小有名气)

【答案】应助回帖

感谢参与,应助指数 +1
不确定你的误差数组B如何和步数对应,所以下面代码只考虑了单一误差,请自行测试

load data;
data123=data(:,1:3); %取原始数据中的1、2、3列
Data4col_uni=unique(data(:,4));
NewArray=[];
for i=1:length(Data4col_uni)
    datafind=find(data(:,4)==i);
    Temp=data123(datafind,; %把循环i的数据取出来
    data12=Temp(:,1:2); %取Temp中的1、2列数据
    Data3col_uni=unique(Temp(:,3));
    for j=1:length(Data3col_uni)
        datafind_1=find(Temp(:,3)==j);
        dataSingleStep=data12(datafind_1,;%把第i循环,第j步时的数据取出来
        if(length(dataSingleStep(:,1))==1)
            NewArray=[NewArray;dataSingleStep];
        else
            x = dataSingleStep(:,1);
            y = dataSingleStep(:,2);
            zx =zeros(length(x),1);
            zy =zeros(length(y),1);
            h = 1;
            zx(1) = x(1);
            zy(1) = y(1);
            for k = 2:length(x)
                if abs(y(k)-y(h)) >= 0.0002
                    zx(h) = x(k);
                    zy(h) = y(k);
                    h = h+1;
                end
            end
            zx(zx==0)=[];
            zy(zy==0)=[];
            NewArrayTemp=[zx,zy];
            NewArray=[NewArray;NewArrayTemp];
        end

    end
end
subplot(2,2,1);
plot(data(:,1),data(:,2),data(:,1),data(:,2),'o');
subplot(2,2,2);
plot(NewArray(:,1),NewArray(:,2),NewArray(:,1),NewArray(:,2),'o');

PS:请给出足够的数据以便进行测试,谢谢。
2楼2012-12-10 19:43:46
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

风泊

铁杆木虫 (小有名气)

【答案】应助回帖

上面的代码中,考虑的原始数据中每一循环内的步数都是从1开始,包括1,2,3,4......这些连续的自然数
3楼2012-12-10 19:52:58
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

btliu

金虫 (小有名气)

引用回帖:
2楼: Originally posted by 风泊 at 2012-12-10 19:43:46
不确定你的误差数组B如何和步数对应,所以下面代码只考虑了单一误差,请自行测试

load data;
data123=data(:,1:3); %取原始数据中的1、2、3列
Data4col_uni=unique(data(:,4));
NewArray=[];
for i=1:length ...

现显示下面的问题,请告知如何处理。非常感谢!
??? Error: File: TESTnew.m Line: 7 Column: 27
Unbalanced or unexpected parenthesis or bracket.

??? Error: File: TESTnew.m Line: 12 Column: 42
Unbalanced or unexpected parenthesis or bracket.
4楼2012-12-10 20:40:50
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖
最具人气热帖推荐 [查看全部] 作者 回/看 最后发表
[考研] 0703化学调剂 ,六级已过,有科研经历 +14 曦熙兮 2026-03-15 14/700 2026-03-21 19:12 by ColorlessPI
[考研] 311求调剂 +12 冬十三 2026-03-15 13/650 2026-03-21 19:07 by ColorlessPI
[考研] 307求调剂 +3 余意卿 2026-03-18 3/150 2026-03-21 17:31 by ColorlessPI
[考研] 求调剂 +3 .m.. 2026-03-21 4/200 2026-03-21 16:25 by barlinike
[考研] 310求调剂 +3 baibai1314 2026-03-16 3/150 2026-03-21 03:56 by JourneyLucky
[考研] 一志愿中国石油大学(华东) 本科齐鲁工业大学 +3 石能伟 2026-03-17 3/150 2026-03-21 02:22 by JourneyLucky
[考研] 085700资源与环境308求调剂 +12 墨墨漠 2026-03-18 13/650 2026-03-21 01:42 by JourneyLucky
[考研] 一志愿华中科技大学,080502,354分求调剂 +5 守候夕阳CF 2026-03-18 5/250 2026-03-21 01:06 by JourneyLucky
[考研] 南京大学化学376求调剂 +3 hisfailed 2026-03-19 6/300 2026-03-20 23:43 by hisfailed
[考研] 308求调剂 +3 阿姐阿姐家啊 2026-03-18 3/150 2026-03-20 23:24 by JourneyLucky
[考研] 304求调剂 +7 司空. 2026-03-18 7/350 2026-03-20 23:08 by JourneyLucky
[考研] 一志愿苏州大学材料求调剂,总分315(英一) +5 sbdksD 2026-03-19 5/250 2026-03-20 22:10 by luoyongfeng
[考研] 086500 325 求调剂 +3 领带小熊 2026-03-19 3/150 2026-03-20 18:38 by 尽舜尧1
[考研] 0856调剂,是学校就去 +8 sllhht 2026-03-19 9/450 2026-03-20 14:25 by 无懈可击111
[考研] 0703化学调剂 +4 18889395102 2026-03-18 4/200 2026-03-19 16:13 by 30660438
[考研] 本科郑州大学物理学院,一志愿华科070200学硕,346求调剂 +4 我不是一根葱 2026-03-18 4/200 2026-03-19 09:11 by 浮云166
[考研] 收复试调剂生 +4 雨后秋荷 2026-03-18 4/200 2026-03-18 14:16 by elevennnne
[考研] 0703化学调剂 +3 妮妮ninicgb 2026-03-17 3/150 2026-03-18 10:29 by macy2011
[考研] 293求调剂 +11 zjl的号 2026-03-16 16/800 2026-03-18 08:10 by zhukairuo
[考研] 290求调剂 +3 p asserby. 2026-03-15 4/200 2026-03-17 16:35 by wangkm
信息提示
请填处理意见