24小时热门版块排行榜    

查看: 633  |  回复: 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的回帖
信息提示
请填处理意见