打印

一个高手对硬件和软件设计的感受

[复制链接]
3601|28
手机看帖
扫描二维码
随时随地手机跟帖
跳转到指定楼层
楼主
someontime|  楼主 | 2012-10-29 14:41 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式
硬件设计是系统设计的关键,国内和国外产品的差距往往是硬件设计水平高低决定的,任何软件设计思想没有可靠的物理载体都是空中楼阁,纸上谈兵。学校的研究生很多都想避开硬件设计,对于一个全新的设计与其说不屑不如说不敢。试想一下烧几个片子的压力要比跑飞几段程序的压力大的多,尤其是功率器件,一旦烧掉,弄不好火光冲天,人的自信都没了。况且改一次板周期长,经费高,还不知行不行。其实在国外实力一般的公司也是尽量避免硬件的更新设计,产品一旦定型往往通过软件升级,这是公司的发展策略,对个人而言物以希为贵,培养一个硬件设计师往往要比软件设计师时间长花费多。在设计dsp硬件时,开始设计最小系统板,系统按功能分板设计调试,注意分板电路的稳定性可能不如整板电路,要多加入抗干扰环节,分板间的引线包括电源线地线要短,尽量在10公分以内,实在不行加入光耦隔离、采用隔离电源。切记电源线、地线的干扰远比信号干扰对系统的危害大得多,又常常被人忽视。电路板工作正常的先决条件就是电源正常!当分板电路正常后再更居情况设计整板电路。在调试时发现的问题一定要找到原因解决,即使是飞线,割线,不要寄希望于下一板改了再看,除非原理性错误。每一个功能环节多准备几套方案。DSP的选型要根据系统功能而定,2000是一个功能比较全的控制器,但运算性能相对低,但目前大部分控制类、家电类包括中低层次的工业总线通信产品足够了,281X不错但太贵,而且开发技术不成熟。54XX更像一个协处理器,其实高端产品5471就很好,功能完*,但BGA封装对产品的开发有一定难度。如果没有从事过嵌入式系统开发的朋友其实可以从51看起,许多思想是共通的,51很经典没有哪一款微处理器像51那样使用持久和普遍。在硬件设计时更多的精力放在外围电路设计上,外围电路设计的灵活性要比DSP本身高得多,难度大得多。建议多考虑CPLD。
软件设计上,着眼点不要仅局限于某种算法和控制策略,而是软件系统框架的制定,即操作系统的选择和实现,算法和控制策略只是其中技巧性很强的子程序和子程序间参数相互关系,建议设计软件时能具有操作系统、数据结构和编译原理方面的知识,特别是使用C。对DSP的内部硬件结构一定要掌握,特别是中断结构和流程、流水线操作,不然飞都不知道怎么飞的。在语言选择上我当时是这么给自己规定的先编20个左右的汇编程序,每个代码量超过4K,使用语句范围覆盖全部语句的60%-70%,在此基础上使用C。现在发现用C构建程序的主体框架(操作系统)比较快而其不容易出错,(我现在正在用ASM根据UCOSII的思想重写自己的操作系统)但对系统实时性影响比较大的运算算法一般采用MATLAB——C——ASM的办法仿真调试优化,这里的优化不单单是利用优化器优化,而是根据数据的特点改变运算方法,以除法为例C里的/号其实掩盖了许多技巧,当除数为常数时就可以放大倒数移位相乘移位的办法进行,精度高速度快。这些办法只有掌握了ASM语言并用ASM语言思考才会熟练应用。另外我想告诉一些作算法特别是控制算法的朋友,千万不要随意评判一个算法的优劣,在程序中程序和代码优化的程度往往影响了控制效果好坏,而不是算法本身的思想。其实在实际中往往PID甚至PI、PD就够了,神经元、模糊、小波适用于研究和写论文,模糊在实际中用的多一点,主要是小日本用的比较成熟,我再恨日本人,这点也服气,小日本就是滑,许多物理现象搞不透,就用这法,还管用,题外话。
最后我想说的是,当我们面对市场要求时,产品往往考虑的是可靠性、性能、价格而不是你用的什么芯片,在满足性能的基础上结构越简单就越可靠,芯片越通用价格就越低,能用51就不用196,能用2407就不用2812,除非把芯片本身作买点利用高成本赢取高利润。无论2000还是5000、6000系列都有市场前景,关键是要做深做透
获取知识的方法、处理项目的能力是相通的,具体的说就是不要把目光盯在做硬件还是做软件上,用ASM还是C,要勤动手打好基础,提高自己对系统总体设计的能力,从系统的眼光看问题。为什么都是做DSP的有的毕业拿3000,有的5000、8000,除了运气和关系外,重要的是你对事物的认识深度和高度。我一直都记住这句话:有前途的人做什么都有前途,没前途的人做什么都没前途。

相关帖子

沙发
someontime|  楼主 | 2012-10-29 14:41 | 只看该作者
很有道理的

使用特权

评论回复
板凳
dwananqinyan| | 2012-10-29 17:08 | 只看该作者
看看

使用特权

评论回复
地板
weishukongji| | 2012-10-29 17:48 | 只看该作者
字好小。。看了半天

使用特权

评论回复
5
strouledfox| | 2012-10-29 18:11 | 只看该作者
学习下

使用特权

评论回复
6
huofeijingfe| | 2012-10-29 18:32 | 只看该作者
- -    不错

使用特权

评论回复
7
xiong87| | 2012-10-29 19:14 | 只看该作者
学习了

使用特权

评论回复
8
sahh| | 2012-10-29 22:08 | 只看该作者
高手通常都不自称高手。

楼主,建议把文字整理一下。

使用特权

评论回复
9
david-xia| | 2012-10-30 13:05 | 只看该作者
学习了

使用特权

评论回复
10
xd54622| | 2012-10-31 16:18 | 只看该作者
:handshake

使用特权

评论回复
11
阿南| | 2012-10-31 17:55 | 只看该作者
确实

使用特权

评论回复
12
mucanhin| | 2012-10-31 18:50 | 只看该作者
-。-学习学习

使用特权

评论回复
13
superman2012| | 2012-10-31 23:24 | 只看该作者
这些总结写得挺好的,挺深刻的,需要好好看看

使用特权

评论回复
14
伯牙绝弦| | 2012-11-1 00:32 | 只看该作者
后面一句精辟!

使用特权

评论回复
15
ni_11199| | 2012-11-1 17:17 | 只看该作者
很经典

使用特权

评论回复
16
hawksabre| | 2012-11-1 21:22 | 只看该作者
最近跟在几个博士后面做项目   感觉他们更看重软件算法这一块   对于硬件电路  基本忽略   能用模块地方绝不会用分立元件来搭   感觉他们好像不屑   其实是水平不行

使用特权

评论回复
17
hawksabre| | 2012-11-1 21:24 | 只看该作者
很多人都说硬件工程师越来越不重要    但是个人觉得   硬件工程师不是不重要   而是因为集成度高了   需要更高的水准   而很多硬件工程师的水平还仅停留在板级设计这块   最终必将被淘汰   个人的一点观点

使用特权

评论回复
评论
waitmoney 2013-7-19 10:52 回复TA
严重同意! 
18
hawksabre| | 2012-11-1 21:27 | 只看该作者
我印象最深的是   现在已经有很多开关电源设计软件    像PI EXPERT   你只需要输入想要的参数  选择好设计的拓扑结构   立马它就能生成一款开关电源   而且是从原理图   PCB图   到BOM表   如果按这个速度   不久大家都会失业   希望这种情况来的越晚越好   呵呵

使用特权

评论回复
评论
waitmoney 2013-7-19 10:55 回复TA
不尽然,中国人不管是援助还是其他的总之被逼着搞起了核武器,这些底层我们也能做。我们解放了精力会做其他的有意义事情的。 
19
denike| | 2012-11-2 15:56 | 只看该作者

使用特权

评论回复
20
daogelas| | 2012-11-3 09:14 | 只看该作者
楼上的太多虑了,
软件结果是需要人验证的

使用特权

评论回复
发新帖 我要提问
您需要登录后才可以回帖 登录 | 注册

本版积分规则

63

主题

982

帖子

0

粉丝