import numpy as np
from ge.es.graph_builder import GraphBuilder, TensorHolder
from ge.graph import Tensor
from ge.graph.types import DataType, Format
from ge.graph import Graph, DumpFormat
from ge.ge_global import GeApi
from ge.session import Session
from ge.es.all import Split
def build_split_graph():
builder = GraphBuilder("MakeSplitGraph")
input_tensor_holder = builder.create_input(
index=0,
name="input",
data_type=DataType.DT_FLOAT,
shape=[8, 16, 64]
)
split_list = Split(1, input_tensor_holder, 4, num_split=4)
for i, tensor in enumerate(split_list):
builder.set_graph_output(tensor, i)
return builder.build_and_reset()
def dump_split_graph(graph):
graph.dump_to_file(format=DumpFormat.kOnnx, suffix="make_split_graph")
def run_graph(graph) -> int:
config = {
"ge.exec.deviceId": "0",
"ge.graphRunMode": "0"
}
ge_api = GeApi()
ret = ge_api.ge_initialize(config)
if ret != 0:
print(f"GE初始化失败,返回码: {ret}")
return ret
print("GE环境初始化成功 (Device ID: 0)")
try:
session = Session()
graph_id = 1
ret = session.add_graph(graph_id, graph)
if ret != 0:
print(f"添加图失败,返回码: {ret}")
return ret
print(f"图已添加到Session (Graph ID: {graph_id})")
tensor_data = np.full(8 * 16 * 64, 1.0, dtype=np.float32)
tensor1 = Tensor(
tensor_data.flatten().tolist(),
None,
DataType.DT_FLOAT,
Format.FORMAT_ND,
shape=[8, 16, 64]
)
input_tensor = [tensor1]
ret = session.run_graph(graph_id, input_tensor)
print("[Info] 图运行成功!")
for idx, tensor in enumerate(ret, start=1):
print(f"Tensor{idx}详情:{tensor}")
return 0
except Exception as e:
print(f"[Error] 执行过程中出错: {e}")
import traceback
traceback.print_exc()
return -1
finally:
print("[Info] 清理GE环境...")
ge_api.ge_finalize()
print("[Success] GE环境已清理")
graph = build_split_graph()
dump_split_graph(graph)
run_graph(graph)