-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathfun_global_var.py
1053 lines (860 loc) · 50.7 KB
/
fun_global_var.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
457
458
459
460
461
462
463
464
465
466
467
468
469
470
471
472
473
474
475
476
477
478
479
480
481
482
483
484
485
486
487
488
489
490
491
492
493
494
495
496
497
498
499
500
501
502
503
504
505
506
507
508
509
510
511
512
513
514
515
516
517
518
519
520
521
522
523
524
525
526
527
528
529
530
531
532
533
534
535
536
537
538
539
540
541
542
543
544
545
546
547
548
549
550
551
552
553
554
555
556
557
558
559
560
561
562
563
564
565
566
567
568
569
570
571
572
573
574
575
576
577
578
579
580
581
582
583
584
585
586
587
588
589
590
591
592
593
594
595
596
597
598
599
600
601
602
603
604
605
606
607
608
609
610
611
612
613
614
615
616
617
618
619
620
621
622
623
624
625
626
627
628
629
630
631
632
633
634
635
636
637
638
639
640
641
642
643
644
645
646
647
648
649
650
651
652
653
654
655
656
657
658
659
660
661
662
663
664
665
666
667
668
669
670
671
672
673
674
675
676
677
678
679
680
681
682
683
684
685
686
687
688
689
690
691
692
693
694
695
696
697
698
699
700
701
702
703
704
705
706
707
708
709
710
711
712
713
714
715
716
717
718
719
720
721
722
723
724
725
726
727
728
729
730
731
732
733
734
735
736
737
738
739
740
741
742
743
744
745
746
747
748
749
750
751
752
753
754
755
756
757
758
759
760
761
762
763
764
765
766
767
768
769
770
771
772
773
774
775
776
777
778
779
780
781
782
783
784
785
786
787
788
789
790
791
792
793
794
795
796
797
798
799
800
801
802
803
804
805
806
807
808
809
810
811
812
813
814
815
816
817
818
819
820
821
822
823
824
825
826
827
828
829
830
831
832
833
834
835
836
837
838
839
840
841
842
843
844
845
846
847
848
849
850
851
852
853
854
855
856
857
858
859
860
861
862
863
864
865
866
867
868
869
870
871
872
873
874
875
876
877
878
879
880
881
882
883
884
885
886
887
888
889
890
891
892
893
894
895
896
897
898
899
900
901
902
903
904
905
906
907
908
909
910
911
912
913
914
915
916
917
918
919
920
921
922
923
924
925
926
927
928
929
930
931
932
933
934
935
936
937
938
939
940
941
942
943
944
945
946
947
948
949
950
951
952
953
954
955
956
957
958
959
960
961
962
963
964
965
966
967
968
969
970
971
972
973
974
975
976
977
978
979
980
981
982
983
984
985
986
987
988
989
990
991
992
993
994
995
996
997
998
999
1000
# -*- coding: utf-8 -*-
"""
Created on Sun Dec 26 22:09:04 2021
@author: Xcz
"""
# %%
import inspect
import math
import numpy as np
from fun_linear import fft2, ifft2
from fun_statistics import U_Drop_n_sigma
# %%
global GLV_DICT_init_times, GLV_init_times, GLV_kwargs_times
GLV_DICT_init_times, GLV_init_times, GLV_kwargs_times = 0, 0, 0
# 如果没有 if_image_add_black_border 充当第一条 含 init 的语句,则要加个 init_GLV_DICT(**kwargs),
# treeprint 不管事,会在桌面上生成一次 all_data_info.txt,无语
def init_GLV_DICT(*args, **kwargs): # 不能只是 **kwargs,还得加 *args,哪怕没有 位置参数
# 否则 init_GLV_DICT() takes 0 positional arguments but 1 was given
global GLV_DICT_init_times
if GLV_DICT_init_times == 0: # 只在第一次初始化的时候,才初始化 DICT,但此时 kwargs 不一定是 第一次初始化 就进来的
global GLOBALS_DICT
GLOBALS_DICT = {}
# print(2, kwargs)
GLV_DICT_init_times += 1
return init_GLV(**kwargs) # (比如若 tree_print 是第一次初始化,则 kwargs 还没进来呢)
def init_GLV(*args, **kwargs): # 不能只是 **kwargs,还得加 *args,哪怕没有 位置参数
global GLV_init_times, GLV_kwargs_times # 只允许一次不带参的初始化,但同时额外 允许一次 带参的初始化
if GLV_init_times == 0: # 原则上,只在第一次 初始化的 时候,才初始化 GLV
is_GLV_init = 1
if len(kwargs) > 0: # 如果第一次 初始化,就有 参数 传进来,则之后 哪怕再带参数 init,也无法 init 了
GLV_kwargs_times += 1
elif len(kwargs) > 0 and GLV_kwargs_times == 0: # 但 额外 允许一次 带参的初始化
is_GLV_init = 1
GLV_kwargs_times += 1
else:
is_GLV_init = 0
GLV_init_times += 1
if is_GLV_init == 1:
# print(3, kwargs)
# %% save 的 data 条目信息
SET("level_min", 1)
SET("attr_separator", kwargs.get("attr_separator", ' ; '))
# %% 不可被 外界改变
item_attr_name_list_save = ["main_py_name", "is_data_saved", "kwargs_seq", "root_dir_boot_times",
"ugHGU", "data_th", "Data_Seq", "Level_Seq",
"saver_name", "U_name", "z_str", "U_name_no_suffix",
"root_dir", "folder_address", "U_address", ]
# 它 不需要是 全局变量,也就意味者:之后顺序 不能改
# 键值(key) 和 键的位置(索引)
SET("item_attr_value_list_save", [None] * len(item_attr_name_list_save)) # 它 得是 全局变量:储存的值
SET("item_attr_name_loc_dict_save", {})
for i in range(len(item_attr_name_list_save)):
GET("item_attr_name_loc_dict_save").update({item_attr_name_list_save[i]: i}) # 键值(key): 键位
# %%
SET("root_dir", gan_root_dir(kwargs.get("root_dir", '')))
# print(GET("root_dir"))
SET("root_dir_boot_times", gan_root_dir_boot_times())
# %%
SET("kwargs_dir", gan_kwargs_dir())
kwargs_seq, kwargs = gan_kwargs_seq(**kwargs) # 更新后的 kwargs 会 被下面的 读取
# 所以尽量把 该行 往上面放;要读其他 非关键参数 的 往下面放
# 关键参数 即在 kwargs 被覆盖之前 就需要读取的 5 个参数:level_min, attr_separator, root_dir, kwargs_dir, kwargs_seq
SET("kwargs_seq", kwargs_seq)
# %%
from fun_os import get_main_py_name
SET("main_py_name", get_main_py_name())
# %% float 显示
SET("F_E", kwargs.get("F_E", ".2e")) # scientific_notation
SET("F_f", kwargs.get("F_f", ".2f"))
SET("f_f", kwargs.get("f_f", "%.2f")) # 小数记数
# %%
SET("size_fig_x_scale", kwargs.get("size_fig_x_scale", 10))
SET("size_fig_y_scale", kwargs.get("size_fig_y_scale", 1))
return kwargs
def SET(key, value): # 只有 init_GLV 中才用;且不调用 init_GLV_DICT(), 这样便可 在 init_GLV_DICT() 中存在(不发生 交叉调用)
try: # 为了不与 set 集合 重名
GLOBALS_DICT[key] = value
return True # 创建 key-value 成功
except KeyError:
return False # 创建 key-value 失败
def GET(key):
try:
return GLOBALS_DICT[key] # 取 value 成功,返回 value
except KeyError:
return False # 取 value 失败
def attr_line_GET(line, item_attr_name): # from line,是 fun_os 中的 attr_get 函数 的 一个 copy
index = GET("item_attr_name_loc_dict_save")[item_attr_name]
# print(line.split(GET("attr_separator")))
if len(line.split(GET("attr_separator"))) >= index+1:
return line.split(GET("attr_separator"))[index]
else:
return None # 等价于 不写 return 即没有 返回值
def gan_root_dir(root_dir):
import os
from fun_os import get_desktop
if root_dir == '':
root_dir_new = get_desktop()
elif root_dir.find('\\') == -1: # 如果 root_dir 既不是 空 也不含 \
root_dir_new = get_desktop() + '\\' + root_dir
else: # 否则 自定义 路径
root_dir_new = root_dir
if not os.path.isdir(root_dir_new): # 得保证 先有 folder
os.makedirs(root_dir_new) # 否则 即使 a+ 模式 也无法 自动创建 Get("root_dir") + "\\" + "all_data_info.txt"
# print(root_dir, root_dir_new)
return root_dir_new
def gan_kwargs_dir():
import os
kwargs_save_dir = GET("root_dir") + '\\' + "ENVs - kwargs_used"
Set("kwargs_save_dir", kwargs_save_dir)
if not os.path.isdir(kwargs_save_dir): # 得保证 先有 folder
os.makedirs(kwargs_save_dir) # 否则 即使 a+ 模式 也无法 自动创建 Get("root_dir") + "\\" + "all_data_info.txt"
return kwargs_save_dir
def gan_root_dir_boot_times():
txt_address = GET("root_dir") + "\\" + "all_data_info.txt"
with open(txt_address, "a+") as txt: # r 或 r+ 会在 根目录 没有 该文件时,报错:所以得先生成,再查看之
txt.seek(0) # 光标移到 txt 开头
lines = txt.readlines()
# print(lines)
if len(lines) > 0: # 如果有内容,其实总能读到 ex_root_dir_boot_times 的,不会读出 None...
line = lines[-1] # 读取最后一行
line = line[:-1]
ex_root_dir_boot_times = attr_line_GET(line, "root_dir_boot_times") # 得到最后一行中的 root_dir_boot_times,把它加 1
root_dir_boot_times = int(ex_root_dir_boot_times) + 1
else:
root_dir_boot_times = GET("level_min") # 把 level 的基数抬升 1:不从 0 开始计。
return root_dir_boot_times # 不转成 str 也行,之后 fun_os 中的 attr_Auto_Set 会自动转
def gan_kwargs_seq(*args, **kwargs):
import os
import json
kwargs_seq = kwargs.get("kwargs_seq", GET("level_min") - 1)
kwargs_seq = kwargs_seq if type(kwargs_seq) == int else GET("level_min")-1
# 还需要 检查文件夹 里,有没有 相应序号 的 储存的 变量列表,不然也返回 GET("level_min")-1,代表 不读取 历史记录中的 json 参数
kwargs_save_full_name = str(kwargs_seq) + ".json"
if (kwargs_seq < Get("root_dir_boot_times") and kwargs_seq >= GET("level_min")) \
or kwargs_save_full_name in os.listdir(GET("kwargs_save_dir")):
# 不看 "all_data_info.txt",如果 "ENVs - kwargs_used" 里 存在这个文件,则也 读取之。
# 如果是 第一次启动,本身就 不满足 读取条件,但 破例 可以任意读 一次;但前提是 存在这个文件。
# 记录的 root_dir_boot_times 里,最低是 GET("level_min"),最高是 Get("root_dir_boot_times") - 1
kwargs_address = GET("kwargs_dir") + "\\" + kwargs_save_full_name
file_json = open(kwargs_address, 'r')
kwargs_dict = json.load(file_json)
else:
# 可能并不满足:所选的 kwargs_seq 在记录的 root_dir_boot_times 们中,而是 kwargs_seq 超出了 旧有记录 范围
# 包括 kwargs_seq 虽 <= Get("root_dir_boot_times"),但 < GET("level_min"),以至于 也没有 在记录范围内
# GET("level_min")-1 等价于 Get("root_dir_boot_times"),等价于 用自己的参数
kwargs_seq = Get("root_dir_boot_times") # 代表 不读取 历史记录中的 json 参数,等价于用自己的参数
kwargs_save_full_name = str(kwargs_seq) + ".json" # 更新 文件名
kwargs_address = GET("kwargs_dir") + "\\" + kwargs_save_full_name
kwargs_dict = {} # 返回一个空字典 or set 集合,类似返回 False,配合 if 的话。
#%% 开始 储存:这次 跑的程序 所用的 参数
kwargs.update(kwargs_dict) # 这次 跑的程序 所用的 参数
kwargs_json = json.dumps(kwargs, sort_keys=False, indent=4, separators=(',', ':')) # dict 转为 json 内 将储存的 str
file_json = open(kwargs_address, 'w') # 创建一个 json 文件
file_json.write(kwargs_json) # 向里面 写入 kwargs 的 json 版 str 内容
return kwargs_seq, kwargs
# %%
def Set(key, value): # 第一次设置值的时候用 Set,以后可直接用 Get(key) = ~
# init_GLV_DICT() # 取消了这个 耗资源的 “万金油”
# 现在的 Set 就是 SET 了,但不保险:需要保证 第一次操作 全局变量前,就初始化好了 全局变量表
try: # 为了不与 set 集合 重名
GLOBALS_DICT[key] = value
return True # 创建 key-value 成功
except KeyError:
return False # 创建 key-value 失败
def Get(key):
# init_GLV_DICT() # 取消了这个 耗资源的 “保险套”
try:
return GLOBALS_DICT[key] # 取 value 成功,返回 value
except KeyError:
return False # 取 value 失败
# %%
def init_GLV_tree_print():
# %%
# tree = "tree_"
#
# Set(tree + "0", ".")
# Set(tree + "1", "├── ")
# Set(tree + "2", "└── ")
# Set(tree + ".", "| ")
#
# def tree_set(tree, level):
# Set(tree + level, Get(tree + ".") * len(re.findall('\.', level)) + Get(tree + level.split('.')[-1]))
# # len(re.findall('\.', level)) 就是 level 中,点的 个数,其实就等于 下面 for 循环中的 i...
#
# sub_levels_num = 4 # 子层级的 层数
# for i in [i+1 for i in range(sub_levels_num)]: # i = 1, 2, 3, ..., sub_levels_num
# tree_set(tree, "." * i + "1")
# tree_set(tree, "." * i + "2")
# %%
# Set("tree_print", [])
#
# Get("tree_print").append([]) # [[]]
# Get("tree_print")[-1].append(".") # [["."]]
# Get("tree_print")[-1].append("├── ") # [[".", "├── "]]
# Get("tree_print")[-1].append("| ") # [[".", "├── ", "| "]]
# Get("tree_print")[-1].append("└── ") # [[".", "├── ", "| ", "└── "]]
# Get("tree_print")[-1].append(" ") # [[".", "├── ", "| ", "└── ", " "]]
#
# sub_levels_num = 4
# for i in [i + 1 for i in range(sub_levels_num)]: # i = 1, 2, 3, ..., sub_levels_num
# Get("tree_print").append([]) # [[".", "├── ", "└── ", "| "], []]
# Get("tree_print")[-1].append(Get("tree_print")[0][2] * i + Get("tree_print")[0][0]) # ["| " * i + "."]
# Get("tree_print")[-1].append(Get("tree_print")[0][2] * i + Get("tree_print")[0][1]) # ["| " * i + "├── "]
# Get("tree_print")[-1].append(Get("tree_print")[0][2] * i + Get("tree_print")[0][-2]) # ["| " * i + "└── "]
# %%
# init_GLV_DICT()
if "tree_print" not in GLOBALS_DICT:
Set("tree_print", [])
Get("tree_print").append(".") # ["."]
Get("tree_print").append("├── ") # [".", "├── "]
Get("tree_print").append("| ") # [".", "├── ", "| "]
Get("tree_print").append("└── ") # [".", "├── ", "| ", "└── "]
Get("tree_print").append(" ") # [".", "├── ", "| ", "└── ", " "]
print(Get("tree_print")[0])
suffix_1 = "_who_called_tree_print"
suffix_2 = "_whose_is_end_equals_to_1"
Set("ex_dir" + suffix_1, "dir_of_.")
Set("level_print", 0)
Set("next_level", 0)
Set("ex_is_end", 0)
Set("dirs" + suffix_2, [[]])
def set_tag_tree_print(level, is_end, ):
if abs(is_end) == 1: # 如果 第 i 层 的 is_end 的 模 = 1,则 该层用 " "
# is_end 可以为 -1,表示 最末一个 最靠外的 层级
Set("tree_print_" + str(level), Get("tree_print")[-1])
else: # 如果 第 i 层 的 is_end != 1,则 该层用 "| "
Set("tree_print_" + str(level), Get("tree_print")[2])
def get_tags_tree_print(level, ):
ex_levels_tags = "" # 查看该层 之前 所有层的 tags (is_end)
for l in range(level):
ex_levels_tags += Get("tree_print_" + str(l)) if Get("tree_print_" + str(l)) else Get("tree_print")[2]
# 如果 Dict 里没 "tree_print_" + str(level) 这个名字,则 return False,则 该层 默认 用 "| "
# 如果有,则返回的值为 " " 或 "| " 而 if 这两个东西 恒为 True
return ex_levels_tags
def info_tree_print(level, is_end=0, ):
# 默认 is_end 为 0,即 该层不是 同类层 peer_levels 的 最后一层(与它有无 子层 sub_levels 没关系),对应 该层用 "├── "
# 即使 is_end = 1,该层也可能有 子层 sub_levels,只需要 是同一个 py 文件里,第 2 次 print 的 就行。
set_tag_tree_print(level, is_end, ) # 设置的是 该层的 tag,可以不传 is_end 进来
ex_levels_tags = get_tags_tree_print(level, ) # 获取的是 该层以前的层的 tags,所以 该层的 tag 对 ex_levels_tags 不起作用
return ex_levels_tags + (
Get("tree_print")[-2] if abs(is_end) == 1 else Get("tree_print")[1]) # 默认用 "├── ",否则用 "└── "
# is_end 可以为 -1,表示 最末一个 最靠外的 层级
def tree_print(is_end=0, add_level=0): # 默认 is_end = 0 ,即 默认 该层不是 同类层的 最后一层
# is_end > 0 后,不再新增 同级层(但仍可能 往下 继续 深入子层级),但该层 完事后,返回上一个 print_level,即 level -= 1,直到 is_end 为 0
init_GLV_tree_print()
list_1d = [list_1d[3] for list_1d in inspect.stack()] # 取 inspect.stack() 每一行的第 3 列,凑成一个 1 维 行 list
list_1d = list_1d[1:] # 删掉 list 中的 第一个 元素,因为 它总是 tree_print
dir = ''.join(list_1d) # 把该 全员字符串的 1 维 行 list 每个元素 加起来,凑成一个 字符串,作为 dir 路径
ex_level = Get("level_print")
suffix_1 = "_who_called_tree_print"
suffix_2 = "_whose_is_end_equals_to_1"
if Get("ex_dir" + suffix_1) in dir: # 如果 上一个 调用 tree_print 的 方法 的 路径,是 这次 调用的 子集,说明 是 横着(平行/同级) 或 往下(子层)走的
# 如果 路径 没变 或 扩增,即使 上一个 print 说是该层最后一个同级,其旗下 也可能有 子层级 sub_levels,且 其子级 的 第 2 次 同级 print 也会 level + 1
# 如果 平着 或 往下走,是第一次重复(第 2 次 dir 无非交集),则产生了 一个新 level 即 level + 1,否则 第 2 次及以上的重复,表示 回到 相同的 py 文件,则 level 不变
if Get("ex_dir" + suffix_1) == dir: # 如果 dir 没变
if not Get(dir + "_" + suffix_1): # 且只重复 1 次,则产生新 level,否则不产生
Set("level_print", ex_level + 1) # 等 新开一个 py 文件 的 第 2 个 print, 才 print_level + 1
Set(dir + "_" + suffix_1, True) # 表示已经 重复过 1 次了:但,同一个完全相同的 dir,在没 退出 本分支之前,只能让 level + 1 一次。
elif Get("ex_is_end") == -1: # 允许在同一 def 里 往回跳 level,主要是 配合 add_level=1:先 level 加 1,再 level 减 1
Set("level_print", ex_level - 1) # 但如果用 is_end=1 会 is_end 记录数 + 1,导致多向前缩进,所以得 is_end=-1 不记录。
# 缩进多了就考虑用 is_end = -1,这个亦真亦假的 is_end
elif (Get("ex_dir" + suffix_1) != dir) and Get("next_level") == 1: # 专门针对 新开的 子 dir 的 第一个 tree_print 提升 层级
Set("level_print", ex_level + 1) # 其第 2 个同级 仍是可 level + 1 的,所以没有 Set(dir + "_" + suffix_1, True)
# ex_is_end = 0 # 推测 上一个 dir 的 is_end 为 0;
# 但这个不一定:几乎 无法预测 上级目录,也就是 每个 def 里 第一个 print 是否是该 level 的 最后一个 同级。
# 无论 is_end 是多少,即无论是否 还有同级,其 dir 都可能有 子分支;所以这里 从“有子分支” 进来,并不能判断 上一个 ex_dir 的 is_end 的值
# ex_dir 有子分支 ≠≠> ex_dir 的 is_end = 0
# 这似乎需要 上上级 dir 给出暗示,那反正都要 传参的,不如将就这里的传 is_end,工作量 是一样的。
# 每个 def 里,第一个 tree_print 的 is_end 是否为 1,需要给。
# 如果 def 里只有 1 个 tree_print,那这个 tree_print 肯定 is_end = 1,但可能有子分支,因而可能往下走,所以往下走 的 is_end 不一定为 0。
elif Get("ex_is_end") != 0:
# 如果 新路径 不再包含 旧路径(有交集 但有 非交集:即 分叉了) 且 上一个 tree_print 的 is_end 不是 0:若是 0 则还有同级,则 level 不变,啥也不做。
# if len(Get("dirs" + suffix_2)[-1]) > 0: # 上一个 tree_print 的 is_end 不是 0,则肯定 len(Get("dirs" + suffix_2)) 不为零
# 且 上一个 print 说后面 没有 同级 peer_levels( 上一个 print 的 is_end > 0);这个判断其实可以没有,如果 is_end 只取 0 或 1 的话。
# print(len(Get("dirs" + suffix_2)[-1])) # 多缩进了的话,启用这个
Set("level_print", ex_level - len(Get("dirs" + suffix_2)[-1])) # level 回跳到 上一层,甚至上几层,取决于 之前声明了多少次 is_end = 1
for DIR in Get("dirs" + suffix_2)[-1]: # 退出 上一的 dir 的 分支 之后,如果再重入那个 module(分支),是可以 继续 level + 1 的
Set(DIR + "_" + suffix_1, False) # 所以 退出之后,得清空 之前所有 is_end = 1 但往下(子 tree) 走了 而 没来得及回跳 的 dir 的 不可重入 标记
# 这里的 DIR 要是写成 dir,会使 下面的 Set("ex_dir" + suffix_1, dir) 中的 dir 是这里的最后一个 DIR 值
Set("dirs" + suffix_2, Get("dirs" + suffix_2)[:-1]) # False 全 Set 之后,把最近邻 is_end = 1 的 dirs 的 储存器 删了(而不是 清空)
# else: # 如果 名称 改变了,且 上一个 print 默认后面 还有 同级 peer_levels( 上一个 print 的 is_end = 0),则 level 不变
# ex_is_end = 1 # 推测 上一个 ex_dir 的 is_end 为 1,不然怎么会 退出 其分支,另开一路 分叉树?
# 还真可以:比如从 args_SFG 中的 Cal_lc_SHG 里返回 并跳到 Cal_GxGyGz 内时
# 延迟 一步 打印 则可 省略每个 def 里 最后一个 tree_print 里填 is_end 值的操作
# ex_dir 没有 子分支 ==> ex_dir 的 is_end = 1,但 ex_dir 有子分支 ≠≠> ex_dir 的 is_end = 0
# 每个 def 里,最后一个 tree_print 的 is_end 必为 1,但 第一个 tree_print 的 is_end 是否为 1,需要给;中间的其他 tree_print 的 is_end 默认为 0 。
# 如果 def 里只有 1 个 tree_print,它既是 最后一个,也是第一个,但默认 它是最后一个。
if len(Get("dirs" + suffix_2)) == 0: # 如果 储存了 is_end=1 的 dirs 是 单层中括号 [],给里面加个 子[],方便后面的 往 子[] 里加东西
Set("dirs" + suffix_2, [[]])
if Get("ex_is_end") == 0 and Get("level_print") == ex_level + 1: # 如果 上一层/个 还有 同级,且 level + 1 了
# print("find") # 该分隔符判断,得在 下面的 is_end = 1 判断 之前:先看前一个的 is_end 判断 是否分隔,再看自己的 is_end,判断是否 is_end 数 + 1
if Get("dirs" + suffix_2)[-1] != []: # 且最末 没有 空容器,则最末 另起一个 空容器(加上分隔符,分开)
Get("dirs" + suffix_2).append(
[]) # 不能每次都减掉 积累的所有 is_end,而是只跳到 上一个 is_end=0 隔开的地方(与最末一个 is_end=1 之间的 is_end=1 们)
if is_end == 1: # is_end 可以为 -1,表示 最末一个 最靠外的 层级
# 此时 必须 不让 is_end 积累数加 1,否则 会多一次 shift + tab 前向缩进;但又得用 "└── ", " " 来显示其和其子层级。
Get("dirs" + suffix_2)[-1].append(dir) # 只给最末一个容器里加 is_end=0 的 dir
# print(is_end, Get("ex_is_end"), ";", Get("level_print"), ex_level)
Set("next_level", 0) # 及时 回归 子 dir 的 第一个 tree_print 默认不 level + 1 的原则(浪费了 强制缩进 的 机会,是不给补的,所以在 所有 if 外
# 如果 在同一个 dir 里,想在第一次 于第 2 个 tree_print 做出子层后,再做出子层,则可考虑 添加 add_level = 1
if add_level == 1: # 原本不加 变加(同一个 def 第 3 个 及以后的 tree_print),但得第 2 个及以后的 tree_print 就调用
Set(dir + "_" + suffix_1, False) # 注意,add_level = 1 后,得下次 调用该 tree_print,level 才会加 1,也有滞后性
elif add_level == 2: # 使接下来 子 dir 的第一个 tree_print 的 level 加 1(跨文件 强制提升层级)
Set("next_level", 1) # add_level > 0 均是 强制缩进,< 0 即 克制自己
Set(dir + "_" + suffix_1, True) # 并且 set 自己该 dir 完成了 level + 1 使命,后续 默认 若该 dir 重复,则 不加 层级了
elif add_level == -1: # 原本加 变不加(同一个 def 第 2 个 tree_print),但得第 1 个 tree_print 就调用
Set(dir + "_" + suffix_1, True) # 注意,add_level = -1 后,得下次 调用该 tree_print,level 才会不加 1,也有滞后性
# 最后才设置这些“上一次”的东西
Set("ex_dir" + suffix_1, dir) # 把这次调用该 print 的 路径,覆盖 之前的,方便 inform 下次是否应该 level + 1
Set("ex_is_end", is_end) # 储存 is_end,方便下次用 这一次的
return info_tree_print(Get("level_print"), is_end, )
# %%
def init_GLV_rmw(U_name, ray_tag, method, way, **kwargs): # kwargs 里面已经有个 ray 的键了
from fun_os import set_ray
ray_set = set_ray(U_name, ray_tag, **kwargs)
Set("ray", ray_set)
Set("method", method)
Set("way", way) # method 肯定有,但 way 不一定有
return ray_set
# %%
def init_accu(key, init_value=0): # 设定一个 全局变量累加器(名称、初值 默认为 0),用于不可重入的计数,或只能进行一次的过程。
# init_GLV_DICT()
if key not in GLOBALS_DICT:
Set(key, init_value)
else:
Set(key, Get(key) + 1)
return Get(key)
def init_Set(key, value): # 同一个 key 名,只在 第一次 Set 时,才 Set
if init_accu("init_" + key + "_times", init_value=0) == 0:
Set(key, value)
def init_tkey(key): # get_format_key:每次调用 tset 的时候,创建一个名为 key_th 的变量,且每次创建的 th 不同
name = key + "_" + "th" # 给 th 取一个与 key 本身 有关的键,这样 对不同名的 key,都可 对他们 独立 累加 其 th
return key + "_" + str(init_accu(name)) # 每次产生一个新的变量名
def init_tset(key, value): # set_format_key_value:每次都 初始化一个 新的 键-值对
name = init_tkey(key) # 初始化一个新的 key_th 名
return Set(name, value), name # 名字也要输出出去,且最好作为局部变量(钥匙),以便之后 直接用 Set(name, value), Get(name) 即可
# %%
def fkey(key): # get_format_key
return Get("method") + ("_" + Get("way") if Get("way") != "" else "") + " - " + key + Get("ray") + "_z"
# 不然会 多出 一条杠 _
def fset(key, value): # set_format_key_value
return Set(fkey(key), value)
def fget(key): # get_format_key_value
return Get(fkey(key))
# %%
def ekey(key): # get_format_key
return Get("method") + ("_" + Get("way") if Get("way") != "" else "") + " - " + key + Get("ray") + "_z_energy"
def eset(key, value): # set_format_key_value
return Set(ekey(key), value)
def eget(key): # get_format_key_value
return Get(ekey(key))
# %%
def dkey(key): # get_format_key
return Get("method") + ("_" + Get("way") if Get("way") != "" else "") + " - " + key + Get("ray") + "_zdz"
def dset(key, value): # set_format_key_value
return Set(dkey(key), value)
def dget(key): # get_format_key_value
return Get(dkey(key))
# %%
def skey(key): # get_format_key
return Get("method") + ("_" + Get("way") if Get("way") != "" else "") + " - " + key + Get("ray") + "_z_stored"
def sset(key, value): # set_format_key_value
return Set(skey(key), value)
def sget(key): # get_format_key_value
return Get(skey(key))
# %%
def YZkey(key): # get_format_key
return Get("method") + ("_" + Get("way") if Get("way") != "" else "") + " - " + key + Get("ray") + "_YZ"
def YZset(key, value): # set_format_key_value
return Set(YZkey(key), value)
def YZget(key): # get_format_key_value
return Get(YZkey(key))
# %%
def XZkey(key): # get_format_key
return Get("method") + ("_" + Get("way") if Get("way") != "" else "") + " - " + key + Get("ray") + "_XZ"
def XZset(key, value): # set_format_key_value
return Set(XZkey(key), value)
def XZget(key): # get_format_key_value
return Get(XZkey(key))
# %%
def key1(key): # get_format_key
return Get("method") + ("_" + Get("way") if Get("way") != "" else "") + " - " + key + Get("ray") + "_sec1"
def set1(key, value): # set_format_key_value
return Set(key1(key), value)
def get1(key): # get_format_key_value
return Get(key1(key))
# %%
def key2(key): # get_format_key
return Get("method") + ("_" + Get("way") if Get("way") != "" else "") + " - " + key + Get("ray") + "_sec2"
def set2(key, value): # set_format_key_value
return Set(key2(key), value)
def get2(key): # get_format_key_value
return Get(key2(key))
# %%
def keyf(key): # get_format_key
return Get("method") + ("_" + Get("way") if Get("way") != "" else "") + " - " + key + Get("ray") + "_front"
def setf(key, value): # set_format_key_value
return Set(keyf(key), value)
def getf(key): # get_format_key_value
return Get(keyf(key))
# %%
def keye(key): # get_format_key
return Get("method") + ("_" + Get("way") if Get("way") != "" else "") + " - " + key + Get("ray") + "_end"
def sete(key, value): # set_format_key_value
return Set(keye(key), value)
def gete(key): # get_format_key_value
return Get(keye(key))
# %%
def init_SSI(g_shift, U_0,
is_energy_evolution_on, is_stored,
sheets_num, sheets_stored_num,
X, Y, Iz, size_PerPixel, ):
Ix, Iy = U_0.shape
# Set("Ix", Ix) # 已经在 其他地方 设定了
# Set("Iy", Iy)
Set("Iz", Iz)
Set("is_energy_evolution_on", is_energy_evolution_on)
Set("is_stored", is_stored)
Set("sheets_num", sheets_num)
Set("sheets_stored_num", sheets_stored_num)
Set("X", X)
Set("Y", Y)
Set("th_X", Iy // 2 + int(X / size_PerPixel))
Set("th_Y", Ix // 2 - int(Y / size_PerPixel))
# %%
if Get("method") == "nLA":
dset("G", g_shift) # 仅为了 B_2_nLA_SSI 而存在
dset("U", U_0) # 仅为了 B_2_nLA_SSI 而存在
else:
dset("G", np.zeros((Ix, Iy), dtype=np.float64())) # 初始化 正确的 矩阵维度 Ix, Iy 和 类型 np.complex128()
dset("U", np.zeros((Ix, Iy), dtype=np.float64())) # 初始化 正确的 矩阵维度 Ix, Iy 和 类型 np.complex128()
if is_energy_evolution_on == 1:
eset("G", np.zeros((sheets_num + 1), dtype=np.float64()))
eset("U", np.zeros((sheets_num + 1), dtype=np.float64()))
eget("G")[0] = np.sum(np.abs(dget("G")) ** 2)
eget("U")[0] = np.sum(np.abs(dget("U")) ** 2)
if abs(is_stored) == 1:
sheet_th_stored = np.zeros(int(sheets_stored_num + 1), dtype=np.int64())
iz_stored = np.zeros(int(sheets_stored_num + 1), dtype=np.float64())
z_stored = np.zeros(int(sheets_stored_num + 1), dtype=np.float64())
Set("for_th_stored", list(np.int64(np.round(np.linspace(0, Get("sheets_num"), Get("sheets_stored_num") + 1)))))
Set("sheet_th_stored", sheet_th_stored) # 设置成全局变量
Set("iz_stored", iz_stored) # 方便之后在这个 py 和 主 py 文件里直接调用
Set("z_stored", z_stored) # 懒得搞 返回 和 获取 这仨了
sset("G", np.zeros((Ix, Iy, int(sheets_stored_num + 1)), dtype=np.complex128()))
sset("U", np.zeros((Ix, Iy, int(sheets_stored_num + 1)), dtype=np.complex128()))
if is_stored == 1:
# 小写的 x,y 表示 电脑中 矩阵坐标系,大写 X,Y 表示 笛卡尔坐标系
YZset("G", np.zeros((Ix, sheets_num + 1), dtype=np.complex128()))
XZset("G", np.zeros((Iy, sheets_num + 1), dtype=np.complex128()))
YZset("U", np.zeros((Ix, sheets_num + 1), dtype=np.complex128()))
XZset("U", np.zeros((Iy, sheets_num + 1), dtype=np.complex128()))
setf("G", np.zeros((Ix, Iy), dtype=np.complex128()))
setf("U", np.zeros((Ix, Iy), dtype=np.complex128()))
sete("G", np.zeros((Ix, Iy), dtype=np.complex128()))
sete("U", np.zeros((Ix, Iy), dtype=np.complex128()))
set1("G", np.zeros((Ix, Iy), dtype=np.complex128()))
set1("U", np.zeros((Ix, Iy), dtype=np.complex128()))
set2("G", np.zeros((Ix, Iy), dtype=np.complex128()))
set2("U", np.zeros((Ix, Iy), dtype=np.complex128()))
def init_EVV(g_shift, U_0,
is_energy_evolution_on, is_stored,
sheets_num, sheets_stored_num,
X, Y, Iz, size_PerPixel, ):
Ix, Iy = U_0.shape
Set("Iz", Iz)
Set("is_energy_evolution_on", is_energy_evolution_on)
Set("is_stored", is_stored)
Set("sheets_num", sheets_num) # sheets_num 相关的 是多余的,尽管如此,也选择了 保留着
Set("sheets_stored_num", sheets_stored_num)
Set("X", X)
Set("Y", Y)
Set("th_X", Iy // 2 + int(X / size_PerPixel))
Set("th_Y", Ix // 2 - int(Y / size_PerPixel))
# %%
if Get("method") == "nLA":
dset("G", g_shift) # 仅为了 B_2_nLA_SSI 而存在
dset("U", U_0) # 仅为了 B_2_nLA_SSI 而存在
else:
dset("G", np.zeros((Ix, Iy), dtype=np.float64())) # 初始化 正确的 矩阵维度 Ix, Iy 和 类型 np.complex128()
dset("U", np.zeros((Ix, Iy), dtype=np.float64())) # 初始化 正确的 矩阵维度 Ix, Iy 和 类型 np.complex128()
if is_energy_evolution_on == 1:
eset("G", np.zeros((sheets_num + 1), dtype=np.float64()))
eset("U", np.zeros((sheets_num + 1), dtype=np.float64()))
eget("G")[0] = np.sum(np.abs(dget("G")) ** 2)
eget("U")[0] = np.sum(np.abs(dget("U")) ** 2)
if abs(is_stored) == 1:
sheet_th_stored = np.zeros(int(sheets_stored_num + 1), dtype=np.int64())
iz_stored = np.zeros(int(sheets_stored_num + 1), dtype=np.float64())
z_stored = np.zeros(int(sheets_stored_num + 1), dtype=np.float64())
Set("sheet_th_stored", sheet_th_stored) # 设置成全局变量
Set("iz_stored", iz_stored) # 方便之后在这个 py 和 主 py 文件里直接调用
Set("z_stored", z_stored) # 懒得搞 返回 和 获取 这仨了
sset("G", np.zeros((Ix, Iy, int(sheets_stored_num + 1)), dtype=np.complex128()))
sset("U", np.zeros((Ix, Iy, int(sheets_stored_num + 1)), dtype=np.complex128()))
if is_stored == 1:
# 小写的 x,y 表示 电脑中 矩阵坐标系,大写 X,Y 表示 笛卡尔坐标系
YZset("G", np.zeros((Ix, sheets_num + 1), dtype=np.complex128()))
XZset("G", np.zeros((Iy, sheets_num + 1), dtype=np.complex128()))
YZset("U", np.zeros((Ix, sheets_num + 1), dtype=np.complex128()))
XZset("U", np.zeros((Iy, sheets_num + 1), dtype=np.complex128()))
# %%
def fun3(for_th, fors_num, G_zdz, *args, **kwargs, ):
if "is_U" in kwargs and kwargs["is_U"] == 1:
U_zdz = G_zdz
G_zdz = fft2(U_zdz)
else:
U_zdz = ifft2(G_zdz)
if Get("is_energy_evolution_on") == 1:
eget("G")[for_th + 1] = np.sum(np.abs(G_zdz) ** 2)
# print(eget("G")[for_th + 1])
eget("U")[for_th + 1] = np.sum(np.abs(U_zdz) ** 2)
# print(eget("U")[for_th + 1])
if abs(Get("is_stored")) == 1:
if for_th in Get("for_th_stored"):
# print(for_th + 1, '\n') # 一共存了 sheets_stored_num + 1 次,所以 把最后一次 预设值 给覆盖了...之后还得重新设...
# print(Get("zj")[for_th + 1])
# 如果 for_th 是 Get("sheets_num") // Get("sheets_stored_num") 的 整数倍(包括零),则 储存之
Get("sheet_th_stored")[Get("for_th_stored").index(for_th)] = for_th + 1
Get("iz_stored")[Get("for_th_stored").index(for_th)] = Get("izj")[for_th + 1]
Get("z_stored")[Get("for_th_stored").index(for_th)] = Get("zj")[for_th + 1]
sget("G")[:, :, Get("for_th_stored").index(for_th)] = G_zdz
# 储存的 第一层,实际上不是 G1_0,而是 G1_dz
sget("U")[:, :, Get("for_th_stored").index(for_th)] = U_zdz
# 储存的 第一层,实际上不是 U_0,而是 U_dz
if Get("is_stored") == 1:
# 小写的 x,y 表示 电脑中 矩阵坐标系,大写 X,Y 表示 笛卡尔坐标系
YZget("G")[:, for_th] = G_zdz[:, Get("th_X")]
# X 增加,则 从 G1_z_shift 中 读取的 列 向右移,也就是 YZ 面向 列 增加的方向(G1_z_shift 的 右侧)移动
XZget("G")[:, for_th] = G_zdz[Get("th_Y"), :]
# Y 增加,则 从 G1_z_shift 中 读取的 行 向上移,也就是 XZ 面向 行 减小的方向(G1_z_shift 的 上侧)移动
YZget("U")[:, for_th] = U_zdz[:, Get("th_X")]
XZget("U")[:, for_th] = U_zdz[Get("th_Y"), :]
# %%
if for_th == Get("sheet_th_frontface"):
# 如果 for_th 是 sheet_th_frontface,则把结构 前端面 场分布 储存起来,对应的是 zj[sheets_num_frontface]
setf("G", G_zdz)
setf("U", U_zdz)
if for_th == Get("sheet_th_endface"):
# 如果 for_th 是 sheet_th_endface,则把结构 后端面 场分布 储存起来,对应的是 zj[sheets_num_endface]
sete("G", G_zdz)
sete("U", U_zdz)
if for_th == Get("sheet_th_sec1"):
# 如果 for_th 是 想要观察的 第一个面 前面那一层的 层序数,则 将储存之于 该层 前面那一层的 后端面(毕竟 算出来的是 z + dz) 分布中
set1("G", G_zdz) # 对应的是 zj[sheets_num_sec1]
set1("U", U_zdz)
if for_th == Get("sheet_th_sec2"):
# 如果 for_th 是 想要观察的 第二个面 前面那一层的 层序数,则 将储存之于 该层 前面那一层的 后端面(毕竟 算出来的是 z + dz) 分布中
set2("G", G_zdz) # 对应的是 zj[sheets_num_sec2]
set2("U", U_zdz)
def Fun3(for_th, fors_num, G_zdz, *args, **kwargs, ):
U_zdz = ifft2(G_zdz)
if Get("is_energy_evolution_on") == 1:
eget("G")[for_th] = np.sum(np.abs(G_zdz) ** 2)
eget("U")[for_th] = np.sum(np.abs(U_zdz) ** 2)
if abs(Get("is_stored")) == 1:
# print(for_th, '\n') # 一共存了 sheets_stored_num + 1 次,所以 把最后一次 预设值 给覆盖了...之后还得重新设...
# print(Get("zj")[for_th])
Get("sheet_th_stored")[for_th] = for_th
Get("iz_stored")[for_th] = Get("izj")[for_th]
Get("z_stored")[for_th] = Get("zj")[for_th]
sget("G")[:, :, for_th] = G_zdz
sget("U")[:, :, for_th] = U_zdz
if Get("is_stored") == 1:
# 小写的 x,y 表示 电脑中 矩阵坐标系,大写 X,Y 表示 笛卡尔坐标系
YZget("G")[:, for_th] = G_zdz[:, Get("th_X")]
# X 增加,则 从 G1_z_shift 中 读取的 列 向右移,也就是 YZ 面向 列 增加的方向(G1_z_shift 的 右侧)移动
XZget("G")[:, for_th] = G_zdz[Get("th_Y"), :]
# Y 增加,则 从 G1_z_shift 中 读取的 行 向上移,也就是 XZ 面向 行 减小的方向(G1_z_shift 的 上侧)移动
YZget("U")[:, for_th] = U_zdz[:, Get("th_X")]
XZget("U")[:, for_th] = U_zdz[Get("th_Y"), :]
if for_th == 0:
# 如果 for_th 是 sheet_th_frontface,则把结构 前端面 场分布 储存起来,对应的是 zj[sheets_num_frontface]
# print(np.sum(np.abs(U_zdz)**2))
setf("G", G_zdz)
setf("U", U_zdz)
if for_th == len(Get("zj")) - 1:
# print(np.sum(np.abs(U_zdz) ** 2))
# 如果 for_th 是 sheet_th_endface,则把结构 后端面 场分布 储存起来,对应的是 zj[sheets_num_endface]
sete("G", G_zdz)
sete("U", U_zdz)
if for_th == 0:
# 如果 for_th 是 想要观察的 第一个面 前面那一层的 层序数,则 将储存之于 该层 前面那一层的 后端面(毕竟 算出来的是 z + dz) 分布中
set1("G", G_zdz) # 对应的是 zj[sheets_num_sec1]
set1("U", U_zdz)
if for_th == len(Get("zj")) - 1:
# 如果 for_th 是 想要观察的 第二个面 前面那一层的 层序数,则 将储存之于 该层 前面那一层的 后端面(毕竟 算出来的是 z + dz) 分布中
set2("G", G_zdz) # 对应的是 zj[sheets_num_sec2]
set2("U", U_zdz)
# %%
def end_AST(z0, size_PerPixel,
g_shift, k1_z, ):
iz = z0 / size_PerPixel
fset("H", np.power(math.e, k1_z * iz * 1j))
fset("G", g_shift * fget("H"))
fset("U", ifft2(fget("G")))
# %%
def end_STD(U1_z, g_shift,
is_energy, n_sigma=3, ): # standard
fset("U", U1_z)
fset("G", fft2(fget("U")))
fset("H", fget("G") / np.max(np.abs(fget("G"))) / (g_shift / np.max(np.abs(g_shift))))
if n_sigma > 0:
# 扔掉 amp 偏离 amp 均值 3 倍于 总体 标准差 以外 的 数据,保留 剩下的 3 倍 以内的 数据。
fset("H", U_Drop_n_sigma(fget("H"), n_sigma, is_energy))
# %%
def end_SSI(g_shift, is_energy, n_sigma=3, **kwargs, ):
if "is_U" in kwargs and kwargs["is_U"] == 1:
fset("U", dget("U"))
fset("G", fft2(fget("U")))
else:
fset("G", dget("G"))
# print(np.max(np.abs(dget("G") / Get("size_PerPixel") ** 2)))
fset("U", ifft2(fget("G")))
# print(np.max(np.abs(fft2(fget("U")) / Get("size_PerPixel") ** 2)))
fset("H", fget("G") / np.max(np.abs(fget("G"))) / (g_shift / np.max(np.abs(g_shift))))
if n_sigma > 0:
# 扔掉 amp 偏离 amp 均值 3 倍于 总体 标准差 以外 的 数据,保留 剩下的 3 倍 以内的 数据。
fset("H", U_Drop_n_sigma(fget("H"), n_sigma, is_energy))
# %%
def fGHU_plot_save(is_energy_evolution_on, # 默认 全自动 is_auto = 1
img_name_extension, is_print,
# %%
zj, sample, size_PerPixel,
is_save, is_save_txt, dpi, size_fig,
# %%
color_1d, cmap_2d,
ticks_num, is_contourf,
is_title_on, is_axes_on, is_mm,
fontsize, font,
# %%
is_colorbar_on, is_energy, # 默认无法 外界设置 vmax 和 vmin,因为 同时画 振幅 和 相位 得 传入 2*2 个 v
# %% 何况 一般默认 is_self_colorbar = 1...
z, **kwargs, ):
from fun_os import GHU_plot_save
if "U" in kwargs:
kwargs.pop("U") # U 容易重名,得在这一级就处理,这样下级的 args 都不用改。
GHU_plot_save(fget("G"), fkey("G"), is_energy_evolution_on, # 这边 要省事 免代入 的话,得确保 提前 传入 ray,way,method 三个参数
eget("G"), is_print,
fget("H"), fkey("H"), # 以及 传入 GHU 这三个 小东西
fget("U"), fkey("U"),
eget("U"),
img_name_extension,
# %%
zj, sample, size_PerPixel,
is_save, is_save_txt, dpi, size_fig,
# %%
color_1d, cmap_2d,
ticks_num, is_contourf,
is_title_on, is_axes_on, is_mm,
fontsize, font,
# %%
is_colorbar_on, is_energy, # 默认无法 外界设置 vmax 和 vmin,因为 同时画 振幅 和 相位 得 传入 2*2 个 v
# %% 何况 一般默认 is_self_colorbar = 1...
z, **kwargs, )
# %%
def fU_SSI_plot(th_f, th_e,
img_name_extension,
is_save_txt,
# %%
sample, size_PerPixel,
is_save, dpi, size_fig,
elev, azim, alpha,
# %%
cmap_2d, cmap_3d,
ticks_num, is_contourf,
is_title_on, is_axes_on, is_mm,
fontsize, font,
# %%
is_colorbar_on, is_colorbar_log,
is_energy, is_show_structure_face,
# %%
plot_group, is_animated,
loop, duration, fps,
# %%
is_plot_EVV, is_plot_3d_XYz, is_plot_selective,
is_plot_YZ_XZ, is_plot_3d_XYZ,
# %%
z_1, z_2,
z_f, z_e, z, **kwargs, ):
from fun_os import U_SSI_plot
if abs(Get("is_stored")) == 1:
Get("sheet_th_stored")[Get("sheets_stored_num")] = Get("sheets_num")
Get("iz_stored")[Get("sheets_stored_num")] = Get("Iz") # 把 sheets_stored_num + 1 这最后一次的值 用 z0 的值 覆盖掉
Get("z_stored")[Get("sheets_stored_num")] = Get("Iz") * Get("size_PerPixel")
sget("G")[:, :, Get("sheets_stored_num")] = fget("G") # 储存的 第一层,实际上不是 G1_0,而是 G1_dz
sget("U")[:, :, Get("sheets_stored_num")] = fget("U") # 储存的 第一层,实际上不是 U_0,而是 U_dz
if Get("is_stored") == 1:
# 小写的 x,y 表示 电脑中 矩阵坐标系,大写 X,Y 表示 笛卡尔坐标系
YZget("G")[:, Get("sheets_num")] = fget("G")[:, Get("th_X")]
XZget("G")[:, Get("sheets_num")] = fget("G")[Get("th_Y"), :]
YZget("U")[:, Get("sheets_num")] = fget("U")[:, Get("th_X")]
XZget("U")[:, Get("sheets_num")] = fget("U")[Get("th_Y"), :]
U_SSI_plot(sget("G"), fkey("G"),
sget("U"), fkey("U"),
YZget("G"), XZget("G"),
YZget("U"), XZget("U"),
get1("G"), get2("G"),
getf("G"), gete("G"),
get1("U"), get2("U"),
getf("U"), gete("U"),
Get("th_X"), Get("th_Y"),
Get("sheet_th_sec1"), Get("sheet_th_sec2"),
th_f, th_e,
img_name_extension,
kwargs.get("is_no_data_save", 0), is_save_txt,
# %%
sample, size_PerPixel,
is_save, dpi, size_fig,
elev, azim, alpha,
# %%
cmap_2d, cmap_3d,
ticks_num, is_contourf,
is_title_on, is_axes_on, is_mm,
fontsize, font,
# %%
is_colorbar_on, is_colorbar_log,
is_energy, is_show_structure_face,
# %%
plot_group, is_animated,
loop, duration, fps,
# %%
is_plot_EVV, is_plot_3d_XYz, is_plot_selective,
is_plot_YZ_XZ, is_plot_3d_XYZ,
# %%
Get("X"), Get("Y"), # 这个也可 顺便 设成 global 的,懒得搞
z_1, z_2,
z_f, z_e,
Get("zj"), Get("z_stored"), z, )
def fU_EVV_plot(img_name_extension,
is_save_txt,
# %%
sample, size_PerPixel,
is_save, dpi, size_fig,
elev, azim, alpha,
# %%
cmap_2d, cmap_3d,
ticks_num, is_contourf,
is_title_on, is_axes_on, is_mm,
fontsize, font,
# %%
is_colorbar_on, is_colorbar_log,
is_energy,
# %%
plot_group, is_animated,
loop, duration, fps,
# %%
is_plot_EVV, is_plot_3d_XYz, is_plot_selective,
is_plot_YZ_XZ, is_plot_3d_XYZ,
# %%
z, **kwargs, ):
from fun_os import U_EVV_plot, U_SSI_plot
if abs(Get("is_stored")) == 1:
Get("sheet_th_stored")[Get("sheets_stored_num")] = Get("sheets_num")
Get("iz_stored")[Get("sheets_stored_num")] = Get("Iz") # 把 sheets_stored_num + 1 这最后一次的值 用 z0 的值 覆盖掉
Get("z_stored")[Get("sheets_stored_num")] = Get("Iz") * Get("size_PerPixel")
sget("G")[:, :, Get("sheets_stored_num")] = fget("G") # 储存的 第一层,实际上不是 G1_0,而是 G1_dz
sget("U")[:, :, Get("sheets_stored_num")] = fget("U") # 储存的 第一层,实际上不是 U_0,而是 U_dz
# 不能有这个,一方面 因为 EVV 的 zj 自带到 z0:np.linspace(0, z0, sheets_stored_num + 1)
# 另一方面,从外部 传了 zj 进 EVV 后,zj 对应的 图都画好了,结果 这里 又把 最后一张图 覆盖了一下...
if Get("is_stored") == 1:
# 小写的 x,y 表示 电脑中 矩阵坐标系,大写 X,Y 表示 笛卡尔坐标系
YZget("G")[:, Get("sheets_num")] = fget("G")[:, Get("th_X")]
XZget("G")[:, Get("sheets_num")] = fget("G")[Get("th_Y"), :]
YZget("U")[:, Get("sheets_num")] = fget("U")[:, Get("th_X")]
XZget("U")[:, Get("sheets_num")] = fget("U")[Get("th_Y"), :]
# U_EVV_plot(sget("G"), fkey("G"),
# sget("U"), fkey("U"),
# img_name_extension,
# is_save_txt,
# # %%
# sample, size_PerPixel,
# is_save, dpi, size_fig,
# elev, azim, alpha,
# # %%
# cmap_2d, cmap_3d,
# ticks_num, is_contourf,
# is_title_on, is_axes_on, is_mm,
# fontsize, font,
# # %%
# is_colorbar_on, is_energy,
# # %%
# plot_group, is_animated,
# loop, duration, fps,
# # %%
# is_plot_3d_XYz,
# # %%
# Get("zj"), Get("z_stored"), z,
# is_no_data_save=is_no_data_save, )
U_SSI_plot(sget("G"), fkey("G"),
sget("U"), fkey("U"),
YZget("G"), XZget("G"),
YZget("U"), XZget("U"),
get1("G"), get2("G"),
getf("G"), gete("G"),
get1("U"), get2("U"),
getf("U"), gete("U"),
Get("th_X"), Get("th_Y"),
0, len(Get("zj")) - 1,
0, len(Get("zj")) - 1,
img_name_extension,
kwargs.get("is_no_data_save", 0), is_save_txt,
# %%
sample, size_PerPixel,
is_save, dpi, size_fig,
elev, azim, alpha,
# %%
cmap_2d, cmap_3d,
ticks_num, is_contourf,
is_title_on, is_axes_on, is_mm,