TensorFlow - Основы

В этой главе мы узнаем об основах TensorFlow. Мы начнем с понимания структуры данных тензора.

Тензорная структура данных

Тензоры используются в качестве базовых структур данных на языке TensorFlow. Тензоры представляют соединяющиеся ребра на любой блок-схеме, называемой графом потока данных. Тензоры определяются как многомерный массив или список.

Тензоры идентифицируются следующими тремя параметрами -

Ранг

Единица размерности, описываемая тензором, называется рангом. Он определяет количество измерений тензора. Ранг тензора можно описать как порядок или n-мерность определенного тензора.

Форма

Количество строк и столбцов вместе определяют форму Tensor.

Тип

Тип описывает тип данных, присвоенный элементам Tensor.

Пользователь должен учитывать следующие действия для создания тензора:

  • Создайте n-мерный массив
  • Преобразуйте n-мерный массив.

Различные измерения TensorFlow

TensorFlow включает в себя различные измерения. Размеры кратко описаны ниже -

Одномерный тензор

Одномерный тензор - это нормальная структура массива, которая включает один набор значений одного и того же типа данных.

Declaration

>>> import numpy as np
>>> tensor_1d = np.array([1.3, 1, 4.0, 23.99])
>>> print tensor_1d

Реализация с выводом показана на скриншоте ниже -

Индексация элементов такая же, как в списках Python. Первый элемент начинается с индекса 0; чтобы распечатать значения через индекс, все, что вам нужно сделать, это указать номер индекса.

>>> print tensor_1d[0]
1.3
>>> print tensor_1d[2]
4.0

Двумерные тензоры

Последовательность массивов используется для создания «двумерных тензоров».

Создание двумерных тензоров описано ниже -

Ниже приведен полный синтаксис для создания двумерных массивов.

>>> import numpy as np
>>> tensor_2d = np.array([(1,2,3,4),(4,5,6,7),(8,9,10,11),(12,13,14,15)])
>>> print(tensor_2d)
[[ 1 2 3 4]
[ 4 5 6 7]
[ 8 9 10 11]
[12 13 14 15]]
>>>

Конкретные элементы двумерных тензоров можно отслеживать с помощью номера строки и номера столбца, заданных как номера индексов.

>>> tensor_2d[3][2]
14

Обработка и манипуляции с тензорами

В этом разделе мы узнаем об обработке и манипуляциях с тензорными элементами.

Для начала давайте рассмотрим следующий код -

import tensorflow as tf
import numpy as np

matrix1 = np.array([(2,2,2),(2,2,2),(2,2,2)],dtype = 'int32')
matrix2 = np.array([(1,1,1),(1,1,1),(1,1,1)],dtype = 'int32')

print (matrix1)
print (matrix2)

matrix1 = tf.constant(matrix1)
matrix2 = tf.constant(matrix2)
matrix_product = tf.matmul(matrix1, matrix2)
matrix_sum = tf.add(matrix1,matrix2)
matrix_3 = np.array([(2,7,2),(1,4,2),(9,0,2)],dtype = 'float32')
print (matrix_3)

matrix_det = tf.matrix_determinant(matrix_3)
with tf.Session() as sess:
   result1 = sess.run(matrix_product)
   result2 = sess.run(matrix_sum)
   result3 = sess.run(matrix_det)

print (result1)
print (result2)
print (result3)

Output

Приведенный выше код сгенерирует следующий вывод -

Объяснение

В приведенном выше исходном коде мы создали многомерные массивы. Теперь важно понимать, что мы создали граф и сеансы, которые управляют тензорами и генерируют соответствующий вывод. С помощью графика у нас есть вывод, определяющий математические вычисления между тензорами.