24小时热门版块排行榜    

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

风泊

铁杆木虫 (小有名气)

【答案】应助回帖

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

[ 发自手机版 http://muchong.com/3g ]
6楼2012-12-10 23:01:12
已阅   回复此楼   关注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的回帖
最具人气热帖推荐 [查看全部] 作者 回/看 最后发表
[考研] 药学305求调剂 +5 玛卡巴卡boom 2026-04-11 5/250 2026-04-14 18:11 by 逍遥三郎
[考研] 085404 22408 309分求调剂 +7 lzmk 2026-04-14 7/350 2026-04-14 17:02 by lihaoda1994
[考研] 290求调剂 +21 luoziheng 2026-04-10 23/1150 2026-04-14 15:49 by zs92450
[考研] 279学硕食品专业求调剂院校 20+6 孤独的狼爱吃羊 2026-04-12 28/1400 2026-04-14 15:44 by zs92450
[考研] 一志愿沪9,326求生物学调剂 +10 刘墨墨 2026-04-13 10/500 2026-04-14 15:16 by zs92450
[考研] 人工智能320调剂08工类还有机会吗 +18 振—TZ 2026-04-10 19/950 2026-04-14 10:34 by screening
[考研] 085600材料与化工349分求调剂 +16 李木子啊哈哈 2026-04-12 17/850 2026-04-14 09:11 by fenglj492
[考研] 机械还有还有名额吗?太难了 +8 笑笑袁 2026-04-10 8/400 2026-04-14 08:44 by screening
[考研] 一志愿211 0703化学 346分求调剂 +26 土豆er? 2026-04-09 29/1450 2026-04-13 15:15 by 独醉梦孤城
[考研] 一志愿鲁东大学071000生物学学硕初试分数276求调剂 +8 慕绝cc 2026-04-09 8/400 2026-04-13 14:08 by 张zhihao
[考研] 22408 352分求调剂 +5 努力的夏末 2026-04-09 5/250 2026-04-12 19:17 by wj165256
[考研] 295分求调剂 +13 ?要上岸? 2026-04-10 13/650 2026-04-12 15:37 by laoshidan
[考研] 本科南方医科大学 一志愿985 药学学硕284分 求调剂 +5 弱水听文 2026-04-09 5/250 2026-04-12 13:16 by shengxi123
[考研] 一志愿华中农微生物,288分,三年实验经历 +11 代fish 2026-04-09 11/550 2026-04-12 10:21 by Hayaay
[找工作] 山东高校教师考核超级无底线,员工过不下去啦 +4 qut2026 2026-04-09 9/450 2026-04-12 00:54 by qut2026
[考研] 277 数一104,学硕,求调剂 +21 瓶子PZ 2026-04-09 23/1150 2026-04-11 23:12 by labixiaoqiao
[考研] 求调剂 +6 电气300求调剂不 2026-04-08 6/300 2026-04-11 20:14 by 逆水乘风
[考研] 0859,337求调剂 +4 研s. 2026-04-10 4/200 2026-04-11 11:34 by caotw2020
[考研] 22408 327分求调剂 +4 韵风kon 2026-04-10 4/200 2026-04-11 09:51 by 猪会飞
[考研] 344求调剂 +7 丶风雪夜归人丶 2026-04-09 7/350 2026-04-10 12:05 by pengliang8036
信息提示
请填处理意见