使用太极编程语言的优势
时间:2022-10-22 16:12:52 阅读:86
用四个字简要概括就是:高效简洁。整体编程体验与Python基本类似;只要能注意Python-scope和Taichi-scope之间的一些编写区别,以及ti.kernel和ti.func函数内部的调用、变量规则,在编写程序时就不会有太大的问题(给太极小伙伴:当然有些报错信息确实可以再详细点hhh~,之前忘记哪次遇到报错但完全没信息的情况。
最重要的一点是:Taichi自身对并行计算的优化非常高,即使是没用到高级数据结构都可以获得很不错的体验。在编写整个蚁群算法时,我基本上没有考虑过效率问题,只要仔细想一下哪一些函数用ti.kernel内的并行for循环会让效率更高即可(2000只蚂蚁的模拟可以有400+fps)。举一个简单的例子,在对蚁群进行更新时,我们可以统一使用ti.kernel内的第一个for循环来遍历每一只蚂蚁,这样Taichi会自动将蚂蚁的运动、信息素释放、检测并行处理。
而如果想要尝试更高级的数据布局,Taichi也可以轻松为张量添加其他布局(例如本模拟器中的信息素浓度分布),例如Block majored。而且只需在编写完代码后稍加修改即可,无需自己重写for循环,详情可见太极官方文档中的高级数据布局部分4,以及太极图形课S1第03讲5。
总之,对于一个外行人来说,taichi的上手很快,而效率又很高。这就已经足够了。taichi https://taichi-lang.cn/
最重要的一点是:Taichi自身对并行计算的优化非常高,即使是没用到高级数据结构都可以获得很不错的体验。在编写整个蚁群算法时,我基本上没有考虑过效率问题,只要仔细想一下哪一些函数用ti.kernel内的并行for循环会让效率更高即可(2000只蚂蚁的模拟可以有400+fps)。举一个简单的例子,在对蚁群进行更新时,我们可以统一使用ti.kernel内的第一个for循环来遍历每一只蚂蚁,这样Taichi会自动将蚂蚁的运动、信息素释放、检测并行处理。
而如果想要尝试更高级的数据布局,Taichi也可以轻松为张量添加其他布局(例如本模拟器中的信息素浓度分布),例如Block majored。而且只需在编写完代码后稍加修改即可,无需自己重写for循环,详情可见太极官方文档中的高级数据布局部分4,以及太极图形课S1第03讲5。
总之,对于一个外行人来说,taichi的上手很快,而效率又很高。这就已经足够了。taichi https://taichi-lang.cn/
郑重声明:文章内容来自互联网,纯属作者个人观点,仅供参考,并不代表本站立场 ,版权归原作者所有!
相关推荐