Как эффективно составить большую матрицу из единиц и нулейPython

Программы на Python
Ответить Пред. темаСлед. тема
Anonymous
 Как эффективно составить большую матрицу из единиц и нулей

Сообщение Anonymous »

У меня есть два массива numpy x и y одинаковой длины, и я пытаюсь создать квадратную матрицу A такую, чтобы запись (i,j) матрицы содержала 1, если между x, x[j], y и y[j] и 0 в противном случае.
Текущий метод, который у меня есть для этого, начинается с A как нулевой матрицы (из размеры len(x) на len(x)) и затем используя двойной цикл for для пробега по всем i и всем j>i (эта матрица симметрична по диагонали). Однако это занимает очень много времени - длина x составляет около 15 000. Подавляющее большинство записей в A будет иметь значение 0, поэтому это кажется весьма неэффективным способом сделать это. Я думал, что можно использовать потенциально замаскированные массивы, но не придумал, как их использовать в этой ситуации. Буду очень признателен за любую помощь!
Вот код, который у меня сейчас есть: df — это фрейм данных, в котором один столбец содержит фамилии, а другой — дату.
import pandas as pd
from datetime import datetime

date_format = '%Y-%m-%d %H:%M:%S'

df1 = pd.DataFrame([['Smith', '2024-12-16 12:00:00'], ['Smith', '2024-12-16 13:00:00'], ['Doe', '2024-12-16 12:01:00'], ['Doe', '2024-12-16 12:04:00']])# -*- coding: utf-8 -*-
df1.columns = ['Surname', 'Date']
df1['Date'] = df1.apply(lambda r : datetime.strptime(r['Date'], date_format),1)

x1 = df1['Surname'].to_numpy()
y1 = df1['Date'].to_numpy()

A1 = scipy.sparse.lil_matrix((len(df1.index), len(df1.index))).todense()
for i in range(len(x1)):
for j in range(i, len(x1)):
A1[i,j] = int((x1 == x1[j]) & (abs(np.timedelta64(y1-y1[j], 'm')) < np.timedelta64(5, 'm')))


Подробнее здесь: https://stackoverflow.com/questions/792 ... -1s-and-0s
Реклама
Ответить Пред. темаСлед. тема

Быстрый ответ

Изменение регистра текста: 
Смайлики
:) :( :oops: :roll: :wink: :muza: :clever: :sorry: :angel: :read: *x)
Ещё смайлики…
   
К этому ответу прикреплено по крайней мере одно вложение.

Если вы не хотите добавлять вложения, оставьте поля пустыми.

Максимально разрешённый размер вложения: 15 МБ.

  • Похожие темы
    Ответы
    Просмотры
    Последнее сообщение
  • Как эффективно составить большую матрицу из единиц и нулей
    Anonymous » » в форуме Python
    0 Ответы
    21 Просмотры
    Последнее сообщение Anonymous
  • Как умножить матрицу 2x3x3x3 на матрицу 2x3, чтобы получить матрицу 2x3
    Anonymous » » в форуме Python
    0 Ответы
    68 Просмотры
    Последнее сообщение Anonymous
  • Как умножить матрицу 2x3x3x3 на матрицу 2x3, чтобы получить матрицу 2x3
    Anonymous » » в форуме Python
    0 Ответы
    60 Просмотры
    Последнее сообщение Anonymous
  • Установить размер стрелки на основе единиц измерения вместо единиц данных оси?
    Anonymous » » в форуме Python
    0 Ответы
    41 Просмотры
    Последнее сообщение Anonymous
  • Самая большая чередующаяся подпоследовательность единиц и нулей в строке
    Anonymous » » в форуме JAVA
    0 Ответы
    11 Просмотры
    Последнее сообщение Anonymous

Вернуться в «Python»