
* fix.. speed_limit error... * draw tpms settings. * fix.. traffic light stopping only.. * fix.. waze cam * fix.. waze... * add setting (Enable comma connect ) * auto detect LFA2 * fix.. cruisespeed1 * vff2 driving model. * fix.. * agnos 12.3 * fix.. * ff * ff * test * ff * fix.. drawTurnInfo.. * Update drive_helpers.py * fix.. support eng voice eng sounds fix settings... english fix.. mph.. fix.. roadlimit speed bug.. * new vff model.. 250608 * fix soundd.. * fix safe exit speed.. * fix.. sounds. * fix.. radar timeStep.. * KerryGold model * Update drive_helpers.py * fix.. model. * fix.. * fix.. * Revert "fix.." This reverts commit b09ec459afb855c533d47fd7e8a1a6b1a09466e7. * Revert "fix.." This reverts commit 290bec6b83a4554ca232d531a911edccf94a2156. * fix esim * add more acc table. 10kph * kg update.. * fix cruisebutton mode3 * test atc..cond. * fix.. canfd * fix.. angle control limit
31 lines
1.0 KiB
Python
31 lines
1.0 KiB
Python
import unittest
|
|
from tinygrad import Tensor
|
|
from tinygrad.helpers import Context
|
|
from tinygrad.uop.ops import Ops
|
|
|
|
class TestRingAllReduce(unittest.TestCase):
|
|
@unittest.skip("still broken")
|
|
def test_schedule_ring(self):
|
|
with Context(RING=2):
|
|
N = 4
|
|
ds = tuple(f"CPU:{i}" for i in range(N))
|
|
t = Tensor.empty(N, N*100).shard(ds, axis=0).realize()
|
|
schedules = t.sum(0).schedule_with_vars()[0]
|
|
copies = [si for si in schedules if si.ast.op is Ops.COPY]
|
|
pairs = [(c.bufs[0].device, c.bufs[1].device) for c in copies]
|
|
# N*(N-1) scatter reduce, and N*(N-1) allgather
|
|
self.assertEqual(len(pairs), N*(N-1)*2)
|
|
# copy topology forms a ring
|
|
self.assertEqual(len(set(pairs)), N)
|
|
|
|
def test_correct_ring(self):
|
|
with Context(RING=2):
|
|
N = 4
|
|
ds = tuple(f"CPU:{i}" for i in range(N))
|
|
t = Tensor.ones(N, N*100).contiguous().shard(ds, axis=0).realize()
|
|
out = t.sum(0)
|
|
self.assertListEqual(out.tolist(), [4]*N*100)
|
|
|
|
if __name__ == '__main__':
|
|
unittest.main()
|