เทนเซอร์โฟลว์:: ขอบเขต
#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::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) | Scope & |
status () const |
ฟังก์ชั่นคงที่สาธารณะ | |
---|---|
NewRootScope () | ส่งกลับขอบเขตใหม่ |
งานสาธารณะ
ColocateWith
Scope ColocateWith( const Operation & op ) const
ส่งกลับขอบเขตใหม่
ops ทั้งหมดที่สร้างขึ้นภายในขอบเขตที่ส่งคืนจะถูกจัดตำแหน่งร่วมกันบนอุปกรณ์ที่วาง op หมายเหตุ: ฟังก์ชันนี้มีจุดประสงค์เพื่อใช้ไลบรารีภายในเพื่อควบคุมการจัดวาง ops บนอุปกรณ์เท่านั้น ไม่สนับสนุนการใช้งานในที่สาธารณะ เนื่องจากการใช้งานการจัดวางอุปกรณ์อาจมีการเปลี่ยนแปลง
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
สถานะ
Status status() const
~ขอบเขต
~Scope()
ฟังก์ชั่นคงที่สาธารณะ
NewRootScope
Scope NewRootScope()
ส่งกลับขอบเขตใหม่
สิ่งนี้จะสร้างกราฟใหม่และการดำเนินการทั้งหมดที่สร้างขึ้นในกราฟนี้ควรใช้วัตถุที่ส่งคืนเป็นขอบเขต "รูท"