training.rst 827 Bytes
Newer Older
Jeff Rasley's avatar
Jeff Rasley committed
1
2
3
Training API
============

Shaden Smith's avatar
Shaden Smith committed
4
5
:func:`deepspeed.initialize` returns a *training engine* in its first argument
of type :class:`DeepSpeedEngine`. This engine is used to progress training:
Jeff Rasley's avatar
Jeff Rasley committed
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20

.. code-block:: python

    for step, batch in enumerate(data_loader):
        #forward() method
        loss = model_engine(batch)

        #runs backpropagation
        model_engine.backward(loss)

        #weight update
        model_engine.step()

Forward Propagation
-------------------
Shaden Smith's avatar
Shaden Smith committed
21
.. autofunction:: deepspeed.DeepSpeedEngine.forward
Jeff Rasley's avatar
Jeff Rasley committed
22
23
24

Backward Propagation
--------------------
Shaden Smith's avatar
Shaden Smith committed
25
.. autofunction:: deepspeed.DeepSpeedEngine.backward
Jeff Rasley's avatar
Jeff Rasley committed
26
27
28

Optimizer Step
--------------
Shaden Smith's avatar
Shaden Smith committed
29
30
31
32
33
34
.. autofunction:: deepspeed.DeepSpeedEngine.step


Gradient Accumulation
---------------------
.. autofunction:: deepspeed.DeepSpeedEngine.is_gradient_accumulation_boundary