24小时热门版块排行榜    

Znn3bq.jpeg
汕头大学海洋科学接受调剂
查看: 696  |  回复: 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的回帖

风泊

铁杆木虫 (小有名气)

【答案】应助回帖

感谢参与,应助指数 +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的回帖

realghost828

金虫 (小有名气)

【答案】应助回帖

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

风泊

铁杆木虫 (小有名气)

【答案】应助回帖

★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★
btliu: 金币+50, ★★★★★最佳答案, 非常感谢! 2012-12-11 09:06:01
那个笑脸的地方是一个冒号和一个右括号,你得改一下

[ 发自手机版 http://muchong.com/3g ]
6楼2012-12-10 23:01:12
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖
相关版块跳转 我要订阅楼主 btliu 的主题更新
最具人气热帖推荐 [查看全部] 作者 回/看 最后发表
[考研] 求调剂 +8 小聂爱学习 2026-04-11 12/600 2026-04-14 18:25 by 小聂爱学习
[考研] 材料工程281还有调剂机会吗 +39 xaw. 2026-04-11 40/2000 2026-04-14 17:28 by zs92450
[考研] 296求调剂 +8 汪!?! 2026-04-09 9/450 2026-04-14 15:15 by 逆水乘风
[考研] 机械工程313分找工科调剂 +4 双一流本科机械 2026-04-08 4/200 2026-04-14 07:32 by Abskk
[考研] 材料复试求调剂 +24 xhhdjdjsjks 2026-04-09 24/1200 2026-04-13 15:49 by 幸免 ..
[考研] 368化学求调剂 +14 wwwwabcde 2026-04-07 15/750 2026-04-13 08:36 by lhj2009
[考研] 求调剂288 +7 ioodiiij 2026-04-10 9/450 2026-04-13 08:33 by Hayaay
[考研] 339求调剂 +8 hanwudada 2026-04-11 9/450 2026-04-12 15:36 by laoshidan
[考研] 0854调剂 +12 长弓傲 2026-04-09 13/650 2026-04-12 09:56 by 逆水乘风
[考研] 一志愿郑州大学 22408 305分求调剂 +5 安小满zzz 2026-04-08 5/250 2026-04-12 00:41 by 蓝云思雨
[考研] 296求调剂 +14 汪!?! 2026-04-08 15/750 2026-04-11 20:28 by dongdian1
[考研] 求调剂 +11 翩翩一书生 2026-04-09 11/550 2026-04-11 19:57 by 逆水乘风
[考研] 求调剂 +6 archer.. 2026-04-09 8/400 2026-04-11 10:55 by zhq0425
[考研] 22408 352分求调剂0854类 +4 努力的夏末 2026-04-09 4/200 2026-04-11 09:57 by zhq0425
[考研] 本9 一志愿西工大085601 324求调剂 +5 wysyjs25 2026-04-10 5/250 2026-04-10 16:57 by luoyongfeng
[考研] 初试261 +3 Asht少 2026-04-10 6/300 2026-04-10 16:38 by Asht少
[考研] 机械专368 有去处吗 +4 种大树 2026-04-10 4/200 2026-04-10 15:31 by jiajinhpu
[论文投稿] 求助文献原文 10+3 18500821399 2026-04-08 3/150 2026-04-09 16:56 by 北京莱茵润色
[考研] 调剂 +12 月@163.com 2026-04-08 12/600 2026-04-09 14:27 by rl1980
[考研] 085801 总分275 本科新能源 求调剂 +8 bradoner 2026-04-08 9/450 2026-04-09 13:43 by only周
信息提示
请填处理意见