硬件开源为什么如此之难?

2015-10-01 16:31 原创 喵酱
4条评论

【编者按】本文来自知乎,由作者@Dee ne 授权转载。

开源硬件会像开源软件给软件业带来的影响那样,也给硬件相关技术(以及硬件团队自身)带来巨大发展吗?这也许是每一个硬件工程师(当然也包括软件工程师)都会思考的问题。硬件与软件毕竟不一样,本文主要从硬件开源与软件开源的区别的角度,来简单说说硬件开源为什么那么难。

首先我们要明确的是:硬件的开源工作远远要比软件复杂。

为什么呢?因为硬件工程相对于软件工程而言,有着以下几个本质的区别:

1、模块化,标准化,以及修改的便捷性

软件产品都有着定义完整,并且可以随时调整输入输出。一旦一个软件模块编写运行测试通过,那么这个模块就可以被视作黑盒子,被另外一个完整定义的模块调用运行。只要软件之间的接口不变,那么各个模块之间的逻辑就不会发生变化,这就使得软件的开发人员之间可以仅仅通过定义好的接口来互相合作,而无论这些开发人员身处何处。

而在硬件领域,工程师们就没有那么幸运了。这个世界上不存在只要知道接口就可以加入设计使用的硬件。硬件的选型是一件很麻烦的事情,即使工作很多年的硬件设计师,在选用从未使用过的硬件设备时,也很有可能在接口电压或是时钟频率的匹配这种“小事情”上栽跟头 —— 随便哪里冒出来的一个接触电阻和寄生电容就可能把整个电路给弄砸了。

硬件设计师们没有强大的IDE(Integrated Development Environment,集成开发环境),没有美好的编译器和解释器,所有硬件工程师都在第一堂EDA(Electronic Design Automation,电子设计自动化)设计课上被告知:“软件仿真是不可靠的,只能作为参考。”硬件设计唯一能依靠的就是扎实的理论基础和反复的实验检测。像是“一个中国工程师和一个美国工程师远距离合作开发出来一个信号采集器”这种在开源软件看来很正常的合作模式,在硬件领域是不可能发生的。硬件设计师们必须坐在一起跑仿真,测芯片,焊板子。

有的人可能就问了:“为什么硬件不能像软件那样标准化,提供接口刷一下rom呢?”

那是因为我们身处的这个物理世界是没办法标准化的。硬件直接和物理世界打交道,老天爷没把这世界做的标准化,我们也没办法。现在硬件模块化已经做的很好了,尤其是数字电路这块。问题主要是模拟电路,电容电感电阻,这些量无处不在,电路的几何形状,材料,加工工艺都会影响这几个参数,实在是没法在设计时标准化。比如,两根导线之间距离的不同所产生的互感和电容差值就可能导致电路无法正常工作,这玩意我觉得实在是很难标准化。设计模块的时候总不可能把所有引脚的线长、线宽、线距都规定好吧?这种问题到了高频和小尺度的时候就会特别明显。

2、生产和发布成本

在软件开发过程中,一旦某个模块的接口需要改变,那么软件工程师所要做的就是坐在电脑前修改代码然后使用短信,电话,email或是git,svn这些工具通知所有需要使用这个模块的人,大家一起调试通过后,修改就完成了。这个过程的沟通成本和修改成本,除了人力以外,基本为零。发布软件的成本那就更低了,以前好歹还需要用软盘光盘这样的载体,现在有了互联网,那基本都是零成本了。

硬件开发的情景则相反,硬件工程师先是千辛万苦跑了无数仿真做出来电路,送到工厂再花不少钞票制作出来之后,示波器、逻辑分析和频谱分析仪(他们都价值不菲)会用严酷的事实告诉你:你这个东西不对。如果你做的是板级电路,那么恭喜你,运气好的话rework其中的某些器件也许就能够拯救你的设计。如果你做的是芯片级设计,那么就准备好再花个几十万做剖面、X光、FIB等找出问题,重新流片看看老天爷是不是能保佑你吧。

硬件的设计修改成本实在是太高了,这也是为什么现在Arduino之类的通用板和IP core的市场这么火的原因。

另外,等做出产品热卖了,那么随之而来的仓储、货运、分销、售后等体系的建设,绝对也是花钱如流水。在硬件产品公司中,开发人员的成本往往只是很小的一部分。

3、入行门槛

在软件业极度发达的今天,任何具有良好逻辑思维能力的人只要感兴趣,就可以通过互联网获得足够的教育从而称为一名软件开发人员。而所有的投资仅仅只是一台可以上网的电脑。这就使得现在的程序员数量不断上升,你总是可以碰到几个闲着找事的程序员一起来合作一些有趣的事情。

而硬件这行当,至今仍然还需要科班出身的专业人员来进行设计开发,我没有见过自学成才的优秀电子硬件设计工程师。为什么呢?仪器耗材只是原因之一;另一方面,硬件设计需要扎实的物理和数学基础。无论是麦克斯韦的电磁理论,还是香农的信息论,亦或是傅立叶/拉普拉斯变换,都不是一朝一夕能够搞明白的,没有大量的时间深入学习和实践,真的很难达到实用的水平。相比之下,hello world和实战之间的距离实在是很近。硬件工程师的培养周期很长,光凭兴趣,靠自学真的很难坚持下去。

就算你只是把硬件买回来组装,自己只是搭板子,其难度也取决于硬件工程师自身的基础和设计目标之间的距离。比如Arduino对新手来说已经算是足够简单了,但要玩转Arduino也至少要懂C、懂单片机、懂各种板级接口。如果要上传感器或电机伺服器的话,至少还得懂点ADC和马达/PID。

培养一名合格的硬件设计工程师,需要大量物理和电子方面的基础理论学习,并且伴随大量使用各种仪器的实习工作,这其中的时间和材料成本是非常高的。硬件工程师数量不多,加上之前提到的协作的困难,使得找一批搞硬件的聚到一起做风险很高的开源工作很不容易。

总而言之,硬件的开源要做起来,就需要克服设计非标准化、成本高、入行门槛高这几个问题。而在我看来,这些问题很难在短时间内被解决。或许像Arduino和IP core这样的解决方案能够在某些领域获得突破,但就总体的电子电路设计而言,我尚未看到很好的开源模式。不过物联网应该是个缓慢持续地将整个社会数字化的过程,我个人认为这个过程将会持续相当长的一段时间(10年以上),这期间会发生什么,还是拭目以待吧。

转载于:https://www.cnblogs.com/zhangfeionline/p/5330011.html

硬件开源为什么如此之难?相关推荐

  1. 十六届智能车全向组硬件开源 | 上海海事大学全向行进组

    简 介: 卓大,不知道你能不能看到我的消息.今年是我做车的第三年了,也是最后一年了.三年里经历了许多,走了很多弯路,心里的感慨也不少.这两天在整理资料的时候顺手在CSDN上写了一篇全向组的硬件开源贴, ...

  2. 硬件开源产品_5种适合户外活动的开源硬件产品

    硬件开源产品 人们在考虑开源硬件时,经常会想到可以焊接且需要电池的电子产品的一般类别. 尽管有许多很棒的开源电子产品,但是开源硬件的整体类别要广泛得多. 本月,我们将介绍可以带到世界各地的开源硬件,无 ...

  3. 硬件开源编程利器MyHDL简介

    来源:CSDN 作者: renzao_ai 硬件开源编程利器MyHDL简介 Verilog缺点 自从1995年Verilog HDL 1364-1995标准发布至今已经20多年了,说他经久不衰并不恰当 ...

  4. 十六届全向组硬件开源

    十六届智能车全向组硬件开源 前言:算法开源已经开始 第一章信号的预处理 第二章边界的提取 写在前面: 我是一个做了三年智能车比赛的本科学生,也是挺菜鸡的一个.国奖也只有一个一等一个二等,和一个划水的三 ...

  5. 【硬件开源电路】STM32G070RBT6开发板

    [硬件开源电路]STM32G070RBT6开发板 ✨制作过程中经历了一些意想不到的坎,在绘制好PCB电路,提交到制作加工厂,工厂解析的Gerber文件中,主控IC焊盘变细,没法正常制作,通过Gerbv ...

  6. 硬件开源需求迫切?开源笔电 Nevona 筹款金额达预设目标3倍

    上个月国外媒体就有新闻报道称,著名硬件黑客Andrew 'Bunnie' Huang和他的合作伙伴Sean "xobs" Cross共通开发了全球首款开源笔记本电脑.不过这款设备主 ...

  7. 2013 年最不可思议的 10 个硬件开源项目

    这篇文章是总结 2013 年发布的最令人不可思议的开源硬件项目,大部分都是众筹项目,这也说明了在 2013 年,开源业界的创新发展很繁荣,受到很大的关注.与此同时,很多大公司,创业公司和个人开发者都开 ...

  8. 开源改变世界概括_为什么任何开源社区都很难改变

    开源改变世界概括 关于Apache基金会如何一直在ApacheCon Budapest上以某种方式做事的简短演讲,由Rich Bowen撰写. 如您所知,Apache Software Foundat ...

  9. 17届智能车-湖科逐梦四队硬件开源

    写在前面的话 时间很快,25号17届智能车湖南赛点就落下了帷幕,由于比赛时候驱动损坏导致无法完赛,特此开源硬件,和大家一同学习交流进步.(充电LCC大概3s,线上赛道26s左右完赛) 充电部分 LCC ...

最新文章

  1. 交换机出现err-disable的原因及解决方法
  2. svm学习之线性部分总结
  3. 前端技术分享:一个超级好用的CSS样式表
  4. 密码学数字信封的介绍
  5. 从Java到Go面向对象--继承思想.md
  6. va_list va_start va_end的使用
  7. 易学易用的Windows PowerShell(转)
  8. Ios html5游戏存档,ios存档怎么安装 不用电脑安装IOS存档图文教程
  9. XCode下Swift – WebView IOS demo
  10. 两台路由器直连服务器需要怎么配置,设置串联两台无线路由器的方法步骤
  11. Laravel 邮件发送
  12. 数据结构PTA 基础实验5-2.2 电话聊天狂人
  13. Java关键字synchronized 使用中的 Double-Checked Locking is Broken
  14. 数据可视化ECharts:ECharts使用
  15. 计算机算log的原理,卡西欧计算器怎么算log1.082(1.0 – 手机爱问
  16. 用热塑技术修复供水(给水)燃气等压力管道的非开挖技术
  17. 怎么才能压缩PDF文件?这两种压缩方法大家都在用
  18. 斯坦福博士生自制的 PPT 生成神器火了!
  19. c语言每个字符占10个字符位左对齐,C语言考前复习资料
  20. opencv VideoCapture抓取RTSP高延迟,崩溃解决方法

热门文章

  1. “大数据”有哪些具体的成功应用?
  2. 同学聚会后我主动埋单,回家后竟被同学们拉黑了,怎么办?
  3. 腾讯正式入局中视频领域
  4. 曾经很火的迅雷,为什么现在不怎么火了?
  5. 以太坊的4个发展阶段与难度炸弹
  6. 【以太坊源码】mpt实现
  7. JAVA(-Xms,Xmx,Xmn-XX:newSize,-XX:MaxnewSize,-XX:PermSize,-XX:MaxPermSize)区别
  8. Codeforces Round #661-C Boats Competition
  9. foxmail占cpu 100%解决办法
  10. oracle12漏洞补丁下载,linux oracle 11g 漏洞补丁升级