เทนเซอร์โฟลว์:: ขอบเขต

#include <scope.h>

วัตถุ Scope แสดงถึงชุดของ TensorFlow ops ที่เกี่ยวข้องซึ่งมีคุณสมบัติเหมือนกัน เช่น คำนำหน้าชื่อสามัญ

สรุป

วัตถุ ขอบเขต คือคอนเทนเนอร์สำหรับคุณสมบัติ TensorFlow Op ตัวสร้าง Op ได้รับวัตถุ ขอบเขต เป็นอาร์กิวเมนต์แรกที่จำเป็นและ op ที่สร้างขึ้นจะได้รับคุณสมบัติในวัตถุ

ตัวอย่างง่ายๆ:

using namespace ops;
Scope root = Scope::NewRootScope();
auto c1 = Const(root, { {1, 1} });
auto m = MatMul(root, c1, { {41}, {1} });
GraphDef gdef;
Status s = root.ToGraphDef(&gdef);
if (!s.ok()) { ... }

ลำดับชั้น ของขอบเขต :

คลาส Scope จัดเตรียมฟังก์ชัน With<> ต่างๆ ที่สร้างขอบเขตใหม่ ขอบเขตใหม่มักจะมีการเปลี่ยนแปลงคุณสมบัติหนึ่งในขณะที่คุณสมบัติอื่นสืบทอดมาจากขอบเขตหลัก NewSubScope(name) method ต่อท้าย name กับส่วนนำหน้าของชื่อสำหรับ ops ที่สร้างขึ้นภายในขอบเขต และ WithOpName() จะเปลี่ยนคำต่อท้ายซึ่งจะเป็นค่าเริ่มต้นของประเภทของ op

ตัวอย่างชื่อ:

Scope root = Scope::NewRootScope();
Scope linear = root.NewSubScope("linear");
// W will be named "linear/W"
auto W = Variable(linear.WithOpName("W"),
                  {2, 2}, DT_FLOAT);
// b will be named "linear/b_3"
int idx = 3;
auto b = Variable(linear.WithOpName("b_", idx),
                  {2}, DT_FLOAT);
auto x = Const(linear, {...});  // name: "linear/Const"
auto m = MatMul(linear, x, W);  // name: "linear/MatMul"
auto r = BiasAdd(linear, m, b); // name: "linear/BiasAdd"

ขอบเขต อายุการใช้งาน:

ขอบเขตใหม่ถูกสร้างขึ้นโดยการเรียก Scope::NewRootScope สิ่งนี้จะสร้างทรัพยากรบางส่วนที่ใช้ร่วมกันโดยขอบเขตย่อยทั้งหมดที่สืบทอดมาจากขอบเขตนี้โดยตรงหรือโดยผ่านสกรรมกริยา ตัวอย่างเช่น ขอบเขตใหม่จะสร้างอ็อบเจ็กต์ Graph ใหม่ซึ่งการดำเนินการจะถูกเพิ่มเมื่อขอบเขตใหม่หรือขอบเขตย่อยถูกใช้โดย Constructor Op ขอบเขตใหม่ยังมีอ็อบเจ็กต์สถานะซึ่งจะใช้เพื่อระบุข้อผิดพลาดโดยฟังก์ชัน Op-constructor ที่เรียกว่าขอบเขตย่อย ฟังก์ชัน Op-constructor ต้องตรวจสอบสถานะของขอบเขตโดยเรียกใช้เมธอด ok() ก่อนดำเนินการสร้าง op

ความปลอดภัยของเกลียว:

วัตถุ Scope ไม่ปลอดภัยสำหรับเธรด เธรดไม่สามารถเรียกฟังก์ชัน op-constructor พร้อมกันบนวัตถุ Scope เดียวกันได้

ตัวสร้างและตัวทำลาย

Scope (const Scope & other)
~Scope ()

งานสาธารณะ

ClearColocation () const
ล้างข้อจำกัด colocation ทั้งหมด
ColocateWith (const Operation & op) const
ส่งกลับขอบเขตใหม่
ColocateWith (const Output & out) const
ฟังก์ชั่นอำนวยความสะดวกสำหรับด้านบน
ExitOnError () const
ส่งกลับขอบเขตใหม่
GetCompositeOpScopes (const string & composite_op_name) const
GetUniqueNameForOp (const string & default_name) const
string
ส่งคืนชื่อที่ไม่ซ้ำ โดยใช้ default_name หากไม่ได้ระบุชื่อ op
NewSubScope (const string & child_scope_name) const
ส่งกลับขอบเขตใหม่
ToGraphDef (GraphDef *gdef) const
Status
ถ้า status() คือ Status::OK() ให้แปลงอ็อบเจ็กต์ Graph ที่จัดเก็บไว้ในขอบเขตนี้เป็นโปรโตของ GraphDef และส่งคืน Status::OK()
UpdateStatus (const Status & s) const
void
อัปเดตสถานะในขอบเขตนี้
WithAssignedDevice (const string & assigned_device) const
ส่งกลับขอบเขตใหม่
WithControlDependencies (const gtl::ArraySlice< Operation > & control_deps) const
ส่งกลับขอบเขตใหม่
WithControlDependencies (const Output & control_dep) const
เช่นเดียวกับข้างต้น แต่สะดวกที่จะเพิ่มการพึ่งพาการควบคุมในการดำเนินการที่สร้างเอาต์พุต control_dep
WithDevice (const string & device) const
ส่งกลับขอบเขตใหม่
WithKernelLabel (const string & kernel_label) const
ส่งกลับขอบเขตใหม่
WithNoControlDependencies () const
ส่งกลับขอบเขตใหม่
WithOpName (Ty... fragments) const
ส่งกลับขอบเขตใหม่
WithXlaCluster (const string & xla_cluster) const
ส่งกลับขอบเขตใหม่
control_deps () const
const std::vector< Operation > &
graph () const
Graph *
graph_as_shared_ptr () const
std::shared_ptr< Graph >
ok () const
bool
operator= (const Scope & other)
status () const
Status

ฟังก์ชั่นคงที่สาธารณะ

NewRootScope ()
ส่งกลับขอบเขตใหม่

งานสาธารณะ

ClearColocation

Scope ClearColocation() const 

ล้างข้อจำกัด colocation ทั้งหมด

ColocateWith

Scope ColocateWith(
  const Operation & op
) const 

ส่งกลับขอบเขตใหม่

ops ทั้งหมดที่สร้างขึ้นภายในขอบเขตที่ส่งคืนจะถูกจัดตำแหน่งร่วมกันบนอุปกรณ์ที่วาง op หมายเหตุ: ฟังก์ชันนี้มีจุดประสงค์เพื่อใช้ไลบรารีภายในเพื่อควบคุมการจัดวาง ops บนอุปกรณ์เท่านั้น ไม่สนับสนุนการใช้งานในที่สาธารณะ เนื่องจากการใช้งานการจัดวางอุปกรณ์อาจมีการเปลี่ยนแปลง

ColocateWith

Scope ColocateWith(
  const Output & out
) const 

ฟังก์ชั่นอำนวยความสะดวกสำหรับด้านบน

ExitOnError

Scope ExitOnError() const 

ส่งกลับขอบเขตใหม่

ฟังก์ชัน op-constructor รับขอบเขตที่ส่งคืนเนื่องจากอาร์กิวเมนต์ขอบเขตจะออกทันทีที่ตรวจพบข้อผิดพลาด แทนที่จะตั้งค่าสถานะบนขอบเขต

GetCompositeOpScopes

CompositeOpScopes GetCompositeOpScopes(
  const string & composite_op_name
) const 

GetUniqueNameForOp

string GetUniqueNameForOp(
  const string & default_name
) const 

ส่งคืนชื่อที่ไม่ซ้ำ โดยใช้ default_name หากไม่ได้ระบุชื่อ op

ขอบเขตย่อยใหม่

Scope NewSubScope(
  const string & child_scope_name
) const 

ส่งกลับขอบเขตใหม่

Ops ที่สร้างด้วยขอบเขตนี้จะมี name/child_scope_name เป็นคำนำหน้า ชื่อจริงจะไม่ซ้ำกันในขอบเขตปัจจุบัน คุณสมบัติอื่นๆ ทั้งหมดสืบทอดมาจากขอบเขตปัจจุบัน หาก child_scope_name ว่างเปล่า เครื่องหมาย / จะถูกตัดออก

ขอบเขต

 Scope(
  const Scope & other
)

ToGraphDef

Status ToGraphDef(
  GraphDef *gdef
) const 

ถ้า status() คือ Status::OK() ให้แปลงอ็อบเจ็กต์ Graph ที่จัดเก็บไว้ในขอบเขตนี้เป็นโปรโตของ GraphDef และส่งคืน Status::OK()

มิฉะนั้น ให้ส่งคืนสถานะข้อผิดพลาดตามที่เป็นอยู่โดยไม่ต้องทำการแปลง GraphDef

UpdateStatus

void UpdateStatus(
  const Status & s
) const 

อัปเดตสถานะในขอบเขตนี้

หมายเหตุ: ออบเจ็กต์สถานะถูกใช้ร่วมกันระหว่างชายน์ทั้งหมดของขอบเขตนี้ ถ้าสถานะผลลัพธ์ไม่ใช่ Status::OK() และ exit_on_error_ ถูกตั้งค่าในขอบเขตนี้ ฟังก์ชันนี้จะออกโดยการเรียก LOG(FATAL)

ด้วยอุปกรณ์ที่ได้รับมอบหมาย

Scope WithAssignedDevice(
  const string & assigned_device
) const 

ส่งกลับขอบเขตใหม่

ops ทั้งหมดที่สร้างขึ้นภายในขอบเขตที่ส่งคืนจะมีอุปกรณ์ที่ได้รับมอบหมายได้รับมอบหมายเป็น assigned_device

ด้วยการควบคุมการพึ่งพา

Scope WithControlDependencies(
  const gtl::ArraySlice< Operation > & control_deps
) const 

ส่งกลับขอบเขตใหม่

ops ทั้งหมดที่สร้างขึ้นภายในขอบเขตที่ส่งคืนจะมีการควบคุมการพึ่งพายูเนียนของการดำเนินการในเวกเตอร์ control_deps และการพึ่งพาการควบคุมของขอบเขตปัจจุบัน

ด้วยการควบคุมการพึ่งพา

Scope WithControlDependencies(
  const Output & control_dep
) const 

เช่นเดียวกับข้างต้น แต่สะดวกที่จะเพิ่มการพึ่งพาการควบคุมในการดำเนินการที่สร้างเอาต์พุต control_dep

ด้วยอุปกรณ์

Scope WithDevice(
  const string & device
) const 

ส่งกลับขอบเขตใหม่

ปฏิบัติการทั้งหมดที่สร้างขึ้นภายในขอบเขตที่ส่งคืนจะมีฟิลด์อุปกรณ์ที่ตั้งค่าเป็น 'อุปกรณ์'

ด้วยKernelLabel

Scope WithKernelLabel(
  const string & kernel_label
) const 

ส่งกลับขอบเขตใหม่

ops ทั้งหมดที่สร้างด้วยขอบเขตใหม่จะมี kernel_label เป็นค่าสำหรับแอตทริบิวต์ '_kernel';

ด้วยNoControlDependencies

Scope WithNoControlDependencies() const 

ส่งกลับขอบเขตใหม่

ops ทั้งหมดที่สร้างขึ้นภายในขอบเขตที่ส่งคืนจะไม่มีการพึ่งพาการควบคุมในการดำเนินการอื่น

ด้วยOpName

Scope WithOpName(
  Ty... fragments
) const 

ส่งกลับขอบเขตใหม่

ops ทั้งหมดที่สร้างภายในขอบเขตที่ส่งคืนจะมีชื่อของฟอร์ม name/StrCat(fragments...)[_suffix]

ด้วยXlaCluster

Scope WithXlaCluster(
  const string & xla_cluster
) const 

ส่งกลับขอบเขตใหม่

ops ทั้งหมดที่สร้างขึ้นภายในขอบเขตที่ส่งคืนจะมีแอตทริบิวต์ _XlaCluster ตั้งค่าเป็น xla_cluster

control_deps

const std::vector< Operation > & control_deps() const 

กราฟ

Graph * graph() const 

graph_as_shared_ptr

std::shared_ptr< Graph > graph_as_shared_ptr() const 

ตกลง

bool ok() const 

โอเปอเรเตอร์=

Scope & operator=(
  const Scope & other
)

สถานะ

Status status() const 

~ขอบเขต

 ~Scope()

ฟังก์ชั่นคงที่สาธารณะ

NewRootScope

Scope NewRootScope()

ส่งกลับขอบเขตใหม่

สิ่งนี้จะสร้างกราฟใหม่และการดำเนินการทั้งหมดที่สร้างขึ้นในกราฟนี้ควรใช้วัตถุที่ส่งคืนเป็นขอบเขต "รูท"