Как я могу создать список точек (двумерных массивов) в Python, используя два списка случайных величин

Я пытаюсь тренировать Перцептрон, используя случайные данные. Кажется, мои данные не соответствуют формату входных данных для класса Perceptron:

Вот как я могу создать мои данные в трее:

Q1 = 100
X1 = 1 + 0.5*np.random.randn(Q1,1)
X2 = 1 + 0.5*np.random.randn(Q1,1)


my_training_inputs = np.array(list(zip(X1, X2)))
my_labels = np.ones((len(X1),))

Вот формат, который я должен подготовить мои данные выше:

training_inputs = []
training_inputs.append(np.array([1, 1]))
training_inputs.append(np.array([1, 0]))
training_inputs.append(np.array([0, 1]))
training_inputs.append(np.array([0, 0]))

labels = np.array([1, 0, 0, 0])

Как я могу подготовить свои данные в этом формате?

2 ответа

Решение

Использование np.concatenate:

Q1 = 100
X1 = 1 + 0.5*np.random.randn(Q1,1)
X2 = 1 + 0.5*np.random.randn(Q1,1)

my_training_inputs = np.concatenate((X1,X2), axis=1)
my_labels = np.ones((len(X1),))   

print(my_labels.shape)
#(100,)

print(my_training_inputs.shape)
#(100, 2)

#print the 4 first samples (inputs)
print(my_training_inputs[0:4])
#array([[0.754558  , 0.76998302],
#       [0.0716354 , 1.34796436],
#       [1.25007314, 1.61079584],
#       [0.74931903, 0.9899375 ]])

Вы не должны добавлять квадратные скобки в определение X1 а также X2, так как np.random.randn(Q1,1) уже является массивом. Просто замените определение X1 а также X2 этим:

X1 = 1 + 0.5*np.random.randn(Q1,1)
X2 = 1 + 0.5*np.random.randn(Q1,1)
Другие вопросы по тегам