*Memos:
- My post explains diag().
- My post explains diagflat().
- My post explains diagonal().
- My post explains diag_embed().
eye() can create the 2D tensor with zero or more 1.(Default), 1, 1.+0.j or True on the diagonal and zero or more 0.(Default), 0, 0.+0.j or False elsewhere as shown below:
*Memos:
-
eye()can be used with torch but not with a tensor. - The 1st argument with
torchisn(Required-Type:int) which is the number of rows. - The 2nd argument with
torchism(Optional-Default:n-Type:int) which is the number of columns. - There is
dtypeargument withtorch(Optional-Default:None-Type:dtype): *Memos:- If it's
None, get_default_dtype() is used. *My post explainsget_default_dtype()and set_default_dtype(). -
dtype=must be used. -
My post explains
dtypeargument.
- If it's
- There is
deviceargument withtorch(Optional-Default:None-Type:str,intor device()): *Memos:- If it's
None, get_default_device() is used. *My post explainsget_default_device()and set_default_device(). -
device=must be used. -
My post explains
deviceargument.
- If it's
- There is
requires_gradargument withtorch(Optional-Default:False-Type:bool): *Memos:-
requires_grad=must be used. -
My post explains
requires_gradargument.
-
- There is
outargument withtorch(Optional-Default:None-Type:tensor): *Memos:-
out=must be used. -
My post explains
outargument.
-
import torch
torch.eye(n=0)
# tensor([], size=(0, 0))
torch.eye(n=1)
# tensor([[1.]])
torch.eye(n=2)
# tensor([[1., 0.],
# [0., 1.]])
torch.eye(n=3)
# tensor([[1., 0., 0.],
# [0., 1., 0.],
# [0., 0., 1.]])
torch.eye(n=4)
# tensor([[1., 0., 0., 0.],
# [0., 1., 0., 0.],
# [0., 0., 1., 0.],
# [0., 0., 0., 1.]])
torch.eye(n=4, m=0)
# tensor([], size=(4, 0))
torch.eye(n=4, m=1)
# tensor([[1.],
# [0.],
# [0.],
# [0.]])
torch.eye(n=4, m=2)
# tensor([[1., 0.],
# [0., 1.],
# [0., 0.],
# [0., 0.]])
torch.eye(n=4, m=3)
# tensor([[1., 0., 0.],
# [0., 1., 0.],
# [0., 0., 1.],
# [0., 0., 0.]])
torch.eye(n=4, m=4)
# tensor([[1., 0., 0., 0.],
# [0., 1., 0., 0.],
# [0., 0., 1., 0.],
# [0., 0., 0., 1.]])
torch.eye(n=4, m=5)
# tensor([[1., 0., 0., 0., 0.],
# [0., 1., 0., 0., 0.],
# [0., 0., 1., 0., 0.],
# [0., 0., 0., 1., 0.]])
torch.eye(n=4, m=6)
# tensor([[1., 0., 0., 0., 0., 0.],
# [0., 1., 0., 0., 0., 0.],
# [0., 0., 1., 0., 0., 0.],
# [0., 0., 0., 1., 0., 0.]])
torch.eye(n=4, m=6, dtype=torch.int64)
# tensor([[1, 0, 0, 0, 0, 0],
# [0, 1, 0, 0, 0, 0],
# [0, 0, 1, 0, 0, 0],
# [0, 0, 0, 1, 0, 0]])
torch.eye(n=4, m=6, dtype=torch.complex64)
# tensor([[1.+0.j, 0.+0.j, 0.+0.j, 0.+0.j, 0.+0.j, 0.+0.j],
# [0.+0.j, 1.+0.j, 0.+0.j, 0.+0.j, 0.+0.j, 0.+0.j],
# [0.+0.j, 0.+0.j, 1.+0.j, 0.+0.j, 0.+0.j, 0.+0.j],
# [0.+0.j, 0.+0.j, 0.+0.j, 1.+0.j, 0.+0.j, 0.+0.j]])
torch.eye(n=4, m=6, dtype=torch.bool)
# tensor([[True, False, False, False, False, False],
# [False, True, False, False, False, False],
# [False, False, True, False, False, False],
# [False, False, False, True, False, False]])
Top comments (0)