-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathstreamlit_app.py
456 lines (339 loc) · 16.1 KB
/
streamlit_app.py
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
310
311
312
313
314
315
316
317
318
319
320
321
322
323
324
325
326
327
328
329
330
331
332
333
334
335
336
337
338
339
340
341
342
343
344
345
346
347
348
349
350
351
352
353
354
355
356
357
358
359
360
361
362
363
364
365
366
367
368
369
370
371
372
373
374
375
376
377
378
379
380
381
382
383
384
385
386
387
388
389
390
391
392
393
394
395
396
397
398
399
400
401
402
403
404
405
406
407
408
409
410
411
412
413
414
415
416
417
418
419
420
421
422
423
424
425
426
427
428
429
430
431
432
433
434
435
436
437
438
439
440
441
442
443
444
445
446
447
448
449
450
451
452
453
454
455
456
import streamlit as st
import requests
from streamlit_lottie import st_lottie
import numpy as np
from PIL import Image
import matplotlib.pyplot as plt
st.set_page_config(page_title="Image Encryption", page_icon="🔐", layout="wide")
def load_lottieurl(url):
r = requests.get(url)
if r.status_code != 200:
return None
return r.json()
lottie_animation = load_lottieurl("https://lottie.host/7fb8dddb-7fe2-4e23-9007-e9ff888795a5/sJvysM9KMx.json")
with st.container():
left_column, right_column = st.columns((2, 1))
with left_column:
st.title("Cipher Crypt")
st.subheader("Coded for Secrecy: Where your images meet impenetrable security.")
with right_column:
st_lottie(lottie_animation, height=150)
st.write("---")
# Image upload section
st.subheader("Upload Images for Encryption/Decryption")
uploaded_file = st.file_uploader("Choose an image...", type=["jpg", "jpeg", "png"])
if uploaded_file is not None:
st.image(uploaded_file, caption="Uploaded Image.",width=400)
st.write("")
encryption_button = st.button("Encrypt Image")
decryption_button = st.button("Decrypt Image")
if encryption_button:
# Add code for encryption here
image = Image.open(uploaded_file)
# Extract RGB values from the original image
rgb_array = np.array(image)
plt.imshow(image)
# Convert the RGB image to grayscale image
gray_image = image.convert('L')
# Convert to numpy array and then to 8-bit binary
gray_array = np.array(gray_image)
# Create bit planes
bit_planes = np.unpackbits(np.expand_dims(gray_array, axis=-1), axis=-1)
# Reshape the bit planes to form a 3D array
bit_planes_3d = bit_planes.reshape(gray_array.shape + (8,))
#BIT PLANES
# Shuffle the binary values in the 3D matrix
shuffled_bit_planes_3d = 1 - bit_planes_3d
# Define the encoding rule
encoding_rule = {
'00': 'A',
'11': 'T',
'01': 'C',
'10': 'G'
}
# Apply the encoding rule to the entire 3D array
def map_to_dna(bit_planes_3d):
# Convert 3D array to 2D array for easy processing
flattened_array = bit_planes_3d.reshape(-1, 8)
# Convert each 8-bit binary value to DNA sequence
dna_sequences = []
for binary_value in flattened_array:
binary_string = ''.join(map(str, binary_value))
binary_pairs = [binary_string[i:i+2] for i in range(0, len(binary_string), 2)]
dna_sequence = ''.join(encoding_rule[pair] for pair in binary_pairs)
dna_sequences.append(dna_sequence)
# Reshape the result back to the original 3D shape
mapped_dna_array = np.array(dna_sequences).reshape(bit_planes_3d.shape[:-1])
return mapped_dna_array
# Apply DNA mapping to the shuffled bit planes
mapped_dna_array = map_to_dna(shuffled_bit_planes_3d)
# Define the transcription rule
transcription_rule = {
'A': 'U',
'T': 'A',
'C': 'G',
'G': 'C'
}
# Apply DNA transcription to the mapped DNA array
def transcribe_dna(mapped_dna_array):
# Iterate over each element in the array and apply transcription rule
transcribed_array = np.vectorize(lambda x: ''.join(transcription_rule[n] for n in x))(mapped_dna_array)
return transcribed_array
# Apply DNA transcription to the mapped DNA array
transcribed_dna_array = transcribe_dna(mapped_dna_array)
# Define the RNA translation rule
rna_translation_rule = {
'A': 'U',
'U': 'G',
'G': 'C',
'C': 'A'
}
# Apply RNA translation to the transcribed DNA array
def translate_rna(transcribed_dna_array):
# Iterate over each element in the array and apply RNA translation rule
translated_rna_array = np.vectorize(lambda x: ''.join(rna_translation_rule[n] for n in x))(transcribed_dna_array)
return translated_rna_array
# Apply RNA translation to the transcribed DNA array
translated_rna_array = translate_rna(transcribed_dna_array)
# Define the RNA mutation rule
rna_mutation_rule = {
'A': 'G',
'U': 'C',
'G': 'A',
'C': 'U'
}
# Apply RNA mutation to the translated RNA array
def mutate_rna(translated_rna_array):
# Iterate over each element in the array and apply RNA mutation rule
mutated_rna_array = np.vectorize(lambda x: ''.join(rna_mutation_rule[n] for n in x))(translated_rna_array)
return mutated_rna_array
# Apply RNA mutation to the translated RNA array
mutated_rna_array = mutate_rna(translated_rna_array)
encryption_rules = {
'A':'00',
'U':'11',
'G':'01',
'C':'10'
}
# Initialize output 3D array
binary_array = np.zeros((len(mutated_rna_array), len(mutated_rna_array[0]), len(mutated_rna_array[0][0])*2), dtype=int)
# Map each base to binary
for i in range(len(mutated_rna_array)):
for j in range(len(mutated_rna_array[i])):
for k, base in enumerate(mutated_rna_array[i][j]):
binary_array[i,j,k*2:k*2+2] = [int(x) for x in encryption_rules[base]]
# Number of rows and columns in the binary_array
num_rows, num_cols, num_channels = binary_array.shape
# Initialize random 3D binary array
binary_array = np.random.randint(0, 2, size=(num_rows, num_cols, num_channels))
# Get dimensions
rows, cols, channels = binary_array.shape
# Create empty image array
image = np.zeros((rows, cols))
# Populate image by summing values across channels
for i in range(rows):
for j in range(cols):
image[i,j] = np.sum(binary_array[i,j,:])
# Normalize to 0-255 range
image = image - np.min(image)
image = (255*image/np.max(image)).astype(np.uint8)
# Display encrypted image
enc_image = Image.fromarray(image)
st.image(enc_image, caption='Encrypted Image',width=400)
st.success("Image Encrypted!")
if decryption_button:
# Add code for decryption here
# Add code for encryption here
image = Image.open(uploaded_file)
# Extract RGB values from the original image
rgb_array = np.array(image)
plt.imshow(image)
# Convert the RGB image to grayscale image
gray_image = image.convert('L')
# Convert to numpy array and then to 8-bit binary
gray_array = np.array(gray_image)
# Create bit planes
bit_planes = np.unpackbits(np.expand_dims(gray_array, axis=-1), axis=-1)
# Reshape the bit planes to form a 3D array
bit_planes_3d = bit_planes.reshape(gray_array.shape + (8,))
#BIT PLANES
# Shuffle the binary values in the 3D matrix
shuffled_bit_planes_3d = 1 - bit_planes_3d
# Define the encoding rule
encoding_rule = {
'00': 'A',
'11': 'T',
'01': 'C',
'10': 'G'
}
# Apply the encoding rule to the entire 3D array
def map_to_dna(bit_planes_3d):
# Convert 3D array to 2D array for easy processing
flattened_array = bit_planes_3d.reshape(-1, 8)
# Convert each 8-bit binary value to DNA sequence
dna_sequences = []
for binary_value in flattened_array:
binary_string = ''.join(map(str, binary_value))
binary_pairs = [binary_string[i:i+2] for i in range(0, len(binary_string), 2)]
dna_sequence = ''.join(encoding_rule[pair] for pair in binary_pairs)
dna_sequences.append(dna_sequence)
# Reshape the result back to the original 3D shape
mapped_dna_array = np.array(dna_sequences).reshape(bit_planes_3d.shape[:-1])
return mapped_dna_array
# Apply DNA mapping to the shuffled bit planes
mapped_dna_array = map_to_dna(shuffled_bit_planes_3d)
# Define the transcription rule
transcription_rule = {
'A': 'U',
'T': 'A',
'C': 'G',
'G': 'C'
}
# Apply DNA transcription to the mapped DNA array
def transcribe_dna(mapped_dna_array):
# Iterate over each element in the array and apply transcription rule
transcribed_array = np.vectorize(lambda x: ''.join(transcription_rule[n] for n in x))(mapped_dna_array)
return transcribed_array
# Apply DNA transcription to the mapped DNA array
transcribed_dna_array = transcribe_dna(mapped_dna_array)
# Define the RNA translation rule
rna_translation_rule = {
'A': 'U',
'U': 'G',
'G': 'C',
'C': 'A'
}
# Apply RNA translation to the transcribed DNA array
def translate_rna(transcribed_dna_array):
# Iterate over each element in the array and apply RNA translation rule
translated_rna_array = np.vectorize(lambda x: ''.join(rna_translation_rule[n] for n in x))(transcribed_dna_array)
return translated_rna_array
# Apply RNA translation to the transcribed DNA array
translated_rna_array = translate_rna(transcribed_dna_array)
# Define the RNA mutation rule
rna_mutation_rule = {
'A': 'G',
'U': 'C',
'G': 'A',
'C': 'U'
}
# Apply RNA mutation to the translated RNA array
def mutate_rna(translated_rna_array):
# Iterate over each element in the array and apply RNA mutation rule
mutated_rna_array = np.vectorize(lambda x: ''.join(rna_mutation_rule[n] for n in x))(translated_rna_array)
return mutated_rna_array
# Apply RNA mutation to the translated RNA array
mutated_rna_array = mutate_rna(translated_rna_array)
encryption_rules = {
'A':'00',
'U':'11',
'G':'01',
'C':'10'
}
# Initialize output 3D array
binary_array = np.zeros((len(mutated_rna_array), len(mutated_rna_array[0]), len(mutated_rna_array[0][0])*2), dtype=int)
# Map each base to binary
for i in range(len(mutated_rna_array)):
for j in range(len(mutated_rna_array[i])):
for k, base in enumerate(mutated_rna_array[i][j]):
binary_array[i,j,k*2:k*2+2] = [int(x) for x in encryption_rules[base]]
# Number of rows and columns in the binary_array
num_rows, num_cols, num_channels = binary_array.shape
# Initialize random 3D binary array
binary_array = np.random.randint(0, 2, size=(num_rows, num_cols, num_channels))
# Get dimensions
rows, cols, channels = binary_array.shape
# Create empty image array
image = np.zeros((rows, cols))
# Populate image by summing values across channels
for i in range(rows):
for j in range(cols):
image[i,j] = np.sum(binary_array[i,j,:])
# Normalize to 0-255 range
image = image - np.min(image)
image = (255*image/np.max(image)).astype(np.uint8)
# Define the reverse RNA mutation rule
reverse_rna_mutation_rule = {
'A': 'G',
'U': 'C',
'G': 'A',
'C': 'U'
}
# Apply reverse RNA mutation to the mutated RNA array
def reverse_mutate_rna(mutated_rna_array):
# Iterate over each element in the array and apply reverse RNA mutation rule
reversed_mutated_rna_array = np.vectorize(lambda x: ''.join(reverse_rna_mutation_rule[n] for n in x))(mutated_rna_array)
return reversed_mutated_rna_array
# Apply reverse RNA mutation to the mutated RNA array
reversed_mutated_rna_array = reverse_mutate_rna(mutated_rna_array)
# Define the reverse RNA translation rule
reverse_rna_translation_rule = {
'A': 'C',
'U': 'A',
'G': 'U',
'C': 'G'
}
# Apply reverse RNA translation to the reversed mutated RNA array
def reverse_translate_rna(reversed_mutated_rna_array):
# Iterate over each element in the array and apply reverse RNA translation rule
reversed_translated_rna_array = np.vectorize(lambda x: ''.join(reverse_rna_translation_rule[n] for n in x))(reversed_mutated_rna_array)
return reversed_translated_rna_array
# Apply reverse RNA translation to the reversed mutated RNA array
reversed_translated_rna_array = reverse_translate_rna(reversed_mutated_rna_array)
# Define the reverse DNA transcription rule
reverse_dna_transcription_rule = {
'A': 'T',
'U': 'A',
'G': 'C',
'C': 'G'
}
# Apply reverse DNA transcription to the reversed translated RNA array
def reverse_transcribe_dna(reversed_translated_rna_array):
# Iterate over each element in the array and apply reverse DNA transcription rule
reversed_transcribed_dna_array = np.vectorize(lambda x: ''.join(reverse_dna_transcription_rule[n] for n in x))(reversed_translated_rna_array)
return reversed_transcribed_dna_array
# Apply reverse DNA transcription to the reversed translated RNA array
reversed_transcribed_dna_array = reverse_transcribe_dna(reversed_translated_rna_array)
# Reverse Encoding Rule
reverse_encoding_rule = {
'A': '00',
'T': '11',
'C': '01',
'G': '10'
}
# Apply the reverse encoding rule to the entire 3D array
def reverse_map_to_dna(reversed_transcribed_dna_array):
# Convert 3D array to 2D array for easy processing
flattened_array = reversed_transcribed_dna_array.reshape(-1)
# Convert each DNA sequence to 8-bit binary values
binary_sequences = []
for dna_sequence in flattened_array:
binary_pairs = [reverse_encoding_rule[base] for base in dna_sequence]
binary_string = ''.join(binary_pairs)
binary_values = [int(bit) for bit in binary_string]
binary_sequences.append(binary_values)
# Reshape the result back to the original 3D shape
reversed_bit_planes_3d = np.array(binary_sequences).reshape(reversed_transcribed_dna_array.shape + (8,))
return reversed_bit_planes_3d
# Apply the reverse DNA mapping to obtain the shuffled bit planes
reversed_bit_planes_3d = reverse_map_to_dna(reversed_transcribed_dna_array)
# Function to unscramble the matrix by flipping 1s to 0s and vice versa
def unscramble_matrix(reversed_bit_planes_3d):
unscrambled_bit_planes_3d = 1 - reversed_bit_planes_3d # Flip 1s to 0s and vice versa
return unscrambled_bit_planes_3d
# Apply the unscrambling operation to the reversed bit planes 3D array
unscrambled_bit_planes_3d = unscramble_matrix(reversed_bit_planes_3d)
# Function to convert a binary matrix to pixel values
def binary_to_pixels(binary_matrix):
flat_binary = binary_matrix.reshape(-1, 8)
pixel_values = [int(''.join(map(str, binary_value)), 2) for binary_value in flat_binary]
pixel_array = np.array(pixel_values, dtype=np.uint8).reshape(binary_matrix.shape[:-1])
return pixel_array
# Assuming you have the unscrambled grayscale image in 'unscrambled_bit_planes_3d'
pixel_image = binary_to_pixels(unscrambled_bit_planes_3d)
# grayscale image
grayscale_image = np.stack((pixel_image,) * 3, axis=-1)
# Display the grayscale image in Streamlit
st.image(grayscale_image, caption='Decrypted Grayscale Image', width=400)
st.image(uploaded_file,width=400)
st.success("Image Decrypted!")