matlab barrier,使用fmincon函数出现barrier问题

迭代到一定次数就出错了

> main

Your initial point x0 is not between bounds lb and ub; FMINCON

shifted x0 to strictly satisfy the bounds.

First-order      Norm of

Iter F-count            f(x)  Feasibility   optimality         step

0     961    1.267130e+03    9.009e+01    7.078e+00

1    1922   -1.670144e+03    5.877e+01    6.122e+00    1.453e+01

2    2883   -3.105103e+03    4.388e+01    4.320e+00    1.553e+01

3    3844   -3.750186e+03    3.556e+01    3.191e+00    7.916e+00

4    4805   -4.556749e+03    2.447e+01    1.609e+00    1.175e+01

5    5766   -5.073551e+03    1.751e+01    1.198e+00    1.012e+01

6    6727   -5.540497e+03    1.205e+01    1.079e+00    1.164e+01

7    7688   -5.936212e+03    5.631e+00    7.465e-01    7.847e+00

In an assignment  A(:) = B, the number of elements in A and B must be the same.

Error in C:\matlab1\toolbox\optim\optim\barrier.p>barrier (line 398)

Error in fmincon (line 900)

[X,FVAL,EXITFLAG,OUTPUT,LAMBDA,GRAD,HESSIAN] = barrier(funfcn,X,A,B,Aeq,Beq,l,u,confcn,options.HessFcn, ...

Error in main (line 13)

[x,fv]=fmincon (@object1,x0,[],[],[],[],v1,v2,@yueshu,options)

那个excel在附件中

第一次求助,感谢各位帮助

5724a1379ceb16a514510c7aa4f77048.gif

2017-3-30 20:01 上传

点击文件名下载附件

22.32 KB, 下载次数: 0

  • 2
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
在CUDA编程中,m_barrier和named barrier是两种常用的线程同步机制,它们可以有效地协调线程之间的合作和同步,提高程序的并行性和效率。 1. m_barrier m_barrier是一种基于硬件实现的线程同步机制,它可以让所有线程在同一时刻停止执行,直到所有线程都到达barrier点。m_barrier使用非常简单,只需要在需要同步的地方调用cudaDeviceSynchronize()函数即可: ``` cudaDeviceSynchronize(); ``` 这样,所有线程都会在该语句处停止执行,直到所有线程都执行完该语句后,才会继续执行下一条语句。 需要注意的是,m_barrier的性能可能受到线程数的影响,因为它需要等待所有线程都到达barrier点才能继续执行。 2. named barrier named barrier是一种基于软件实现的线程同步机制,它可以让不同线程块之间进行同步,提高程序的并行性和效率。named barrier需要先创建一个barrier对象,然后在需要同步的地方调用barrier.sync()函数进行同步。 例如,可以使用以下代码创建一个named barrier对象: ``` cuda::barrier<cuda::thread_scope_block> my_barrier(blockDim.x); ``` 其中,cuda::thread_scope_block表示线程块作用域,blockDim.x表示线程块的大小。 然后,可以在需要同步的地方调用my_barrier.sync()函数进行同步: ``` my_barrier.sync(); ``` 需要注意的是,named barrier的性能可能受到线程块数的影响,因为它需要等待所有线程块都到达barrier点才能继续执行。 总的来说,m_barrier和named barrier都是重要的线程同步机制,在CUDA编程中应用广泛。需要根据具体情况选择合适的同步机制,并进行优化以提高程序的效率。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值