太极图形学——性能调优——Debugging

在课程中的太极不支持断点调优的功能

运行工程出的打印,打印的顺序是不一定的,打印是非常消耗性能的,因此只有在debug的时候才会使用

在python中,打印有很多种语法,但在太极核中,支持的比较少

#print
@ti.kernel
def foo():
    print("a[0] = ", a[0])#可行的
    print(f'a[0] = {a[0]}')#不可行的 
    print("a[0] = %f" % a[0])#不可行的

不损耗性能的print,可以得到一些维度信息等等,只在编译的时候运行一次,用来检查一些常量是不是对的

x = ti.field(ti.f32,(2,3))
y = 1
A = ti.Matrix([1,2],[3,4],[5,6])

@ti.kernel
def inside_taichi_scope():
    ti.static_print(y)
    # =>1
    ti.static_print(x.shape)
    # => (2,3)
    ti.static_print(A.n)
    # => 3
    for i in range(4):
        ti.static_print(A.m)
        # => 2
        #只在编译的时候打印以此一次

检查field,使用gui可视化

#field
import taichi as ti
ti.init(arch=ti.gpu)
x = ti.field(ti.f32,(256,256))

@ti.kernel
def foo():
    for i,j in x:
        x[i,j] = (i+j)/512.0

foo()

gui = ti.GUI("Debug", (256,256))
while gui.running:
    gui.set_image(x)
    gui.show()

结果如下图

确保debug模式开启,当debug模式开启后会检查所有的断言,可以抛出数组越界等错误,或者人为的定义一些断言,再就是assert中不要放任何有关于计算的部分,因为这会在release版本中被省略

#debug mode
ti.init(arch=ti.cpu,debug = True)
x = ti.filed(ti.f32,shape = 4)
print("x[4] =",x[4]) #Error

x  = ti.field(ti.f32,128)

@ti.kernel
def do_sqrt_all():
    for i in x:
        assert x[i] >= 0
        y[i] = ti.sqrt(y[i])

编译时候的断言,检查维度和形状 

@ti.func
def copy(dst: ti.template(), src: ti.template()): # type: ignore
    ti.static_assert(dst.shape == src.shape, "copy: shape mismatch")
    for i  in ti.grouped(src):
        dst[i] = src[i]
    return x % 2 == 1
import taichi as ti
ti.init(arch=ti.cpu,excepthook = True)

@ti.func
def func3():
    ti.static_assert(1+1 == 3)

@ti.func
def func2():
    func3()

@ti.func
def func1():
    func2()

@ti.kernel
def func0():
    func1()

func0()

在进行一些疑难代码的调试时,关闭并行计算和太极自身的代码优化

#parallelization closed
import taichi as ti
ti.init(arch = ti.cpu,cpu_max_num_threads = 1)
# advanced optimization closed
ti.init(advanced_optimization = False)

最后是一个代码习惯 模块化编程并随时检查base和block本身是否都可以执行

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值