Chắc là không. Các hệ thống mã hóa hiện đại được thiết kế xung quanh các bộ tạo số ngẫu nhiên mật mã, đầu ra của chúng được thiết kế để không thể phân biệt được về mặt thống kê với tính ngẫu nhiên thực sự. Học máy nói chung dựa trên việc khám phá các mẫu thống kê trong dữ liệu và với dữ liệu thực sự ngẫu nhiên thì không có. Ngay cả đối với tiền điện tử không hoàn hảo, nơi có một số mẫu nhỏ được tìm thấy, số lượng lớn ngẫu nhiên trong đầu vào sẽ áp đảo bất kỳ nỗ lực trực tiếp nào để giải mã bản mã.
Ngoài ra, không có heuristic nào bạn có thể sử dụng để biết liệu bạn có đang tiến gần đến một giải mã chính xác hay không - một ví dụ trong một lần đoán tại một khóa chẳng hạn sẽ làm xáo trộn hoàn toàn đầu ra (đổ lỗi cho Hollywood khi nó hiển thị giải mã trên màn hình như một số câu đố ô chữ trong đó các chữ cái chính xác rơi vào vị trí). Rằng tất cả hoặc không có gì loại trừ việc khám phá các thuật toán thông qua quy trình học máy, ngay cả khi bạn có khóa mã hóa. Điều tốt nhất bạn có thể làm là vũ phu tất cả các thuật toán đã biết. Nếu bạn không có chìa khóa, thì bạn cũng phải vũ phu tất cả các phím có thể.
Bạn có thể khám phá mức độ khó của vấn đề bằng cách cố gắng đoán giá trị hạt giống được sử dụng cho trình tạo số ngẫu nhiên. Sử dụng Mersenne Twister RNG (tiêu chuẩn được sử dụng trong ví dụ Python), thì đầu vào có thể là mẫu bit cho 624 số nguyên không dấu 32 bit và đầu ra có thể là 32 bit của hạt giống được sử dụng để tạo chuỗi đó. Lý do tôi đề nghị những con số cụ thể là bởi vì nó là trong thực tế có thể để crack Mersenne Twister với nhiều dữ liệu. Tuy nhiên, tôi vẫn nghĩ rằng các phương pháp ML sẽ hoàn toàn là công cụ sai lầm để làm điều đó.
Một biến thể đơn giản khác là để xem liệu bạn có thể dạy một mạng để sản xuất hoặc đảo ngược hàm băm mật mã hay không. Bạn có thể bắt đầu với một cái bị hỏng đã biết, chẳng hạn như MD5. Đầu vào và đầu ra có thể là 80 bit, giúp đơn giản hóa kiến trúc và đường ống đủ để bạn có thể kết hợp thử nghiệm này trong vài giờ. Mặc dù MD5 được biết là bị xâm phạm, tôi nghĩ không có cơ hội nào bạn có thể dạy một mạng lưới thần kinh để tìm bất kỳ mẫu nào.
Một chi tiết quan trọng: Nếu bạn muốn "bẻ khóa" mã hóa, bạn sẽ không thể sử dụng khóa làm giá trị đã biết. Tuy nhiên, rất có thể, ngay cả khi bạn cung cấp chìa khóa cho quy trình ML, nó sẽ không thể học cách giải mã.