راهنمای سبک مستندسازی TensorFlow

بهترین شیوه ها

  • روی هدف کاربر و مخاطب تمرکز کنید.
  • از کلمات روزمره استفاده کنید و جملات را کوتاه نگه دارید.
  • از ساخت جمله، جمله بندی و حروف بزرگ استفاده کنید.
  • از سرفصل‌ها و فهرست‌ها برای آسان‌تر کردن اسکن اسناد خود استفاده کنید.
  • راهنمای سبک اسناد توسعه‌دهنده Google مفید است.

مارک داون

با چند استثنا، TensorFlow از یک دستور Markdown مشابه با GitHub Flavored Markdown (GFM) استفاده می کند. این بخش تفاوت های بین نحو GFM Markdown و Markdown مورد استفاده برای اسناد TensorFlow را توضیح می دهد.

در مورد کد بنویسید

ذکر درون خطی کد

هنگام استفاده در متن `backticks` در اطراف نمادهای زیر قرار دهید:

  • نام آرگومان‌ها: `input` ، `x` ، `tensor`
  • نام‌های تانسور برگشتی: `output` ، `idx` ، `out`
  • انواع داده: `int32` ، `float` ، `uint8`
  • سایر نام‌های عملیات مرجع در متن: `list_diff()` , `shuffle()`
  • نام کلاس ها: `tf.Tensor` ، `Strategy`
  • نام فایل: `image_ops.py` , `/path_to_dir/file_name`
  • عبارات یا شرایط ریاضی: `-1-input.dims() <= dim <= input.dims()`

بلوک های کد

از سه بکتیک برای باز و بسته کردن یک بلوک کد استفاده کنید. به صورت اختیاری، زبان برنامه نویسی را بعد از اولین گروه بکتیک مشخص کنید، به عنوان مثال:


```python
# some python code here
```

از پیوندهای نسبی بین فایل‌ها در یک مخزن GitHub استفاده کنید. پسوند فایل را وارد کنید.

به عنوان مثال، این فایلی که می خوانید از مخزن https://github.com/tensorflow/docs است. بنابراین، می‌تواند از مسیرهای نسبی برای پیوند به فایل‌های دیگر در همان مخزن مانند زیر استفاده کند:

  • [Basics](../../guide/basics.ipynb) Basics را تولید می کند.

این رویکرد ترجیحی است زیرا به این ترتیب پیوندهای موجود در tensorflow.org ، GitHub و Colab همگی کار می کنند. همچنین، خواننده زمانی که روی یک لینک کلیک می کند، در همان سایت می ماند.

برای پیوند به فایل‌هایی که در مخزن فعلی نیستند، از پیوندهای Markdown استاندارد با URI کامل استفاده کنید. اگر URI tensorflow.org در دسترس است، ترجیح دهید به آن پیوند دهید.

برای پیوند به کد منبع، از پیوندی استفاده کنید که با https://www.github.com/tensorflow/tensorflow/blob/master/ شروع می شود و سپس نام فایل از ریشه GitHub شروع می شود.

هنگام اتصال به tensorflow.org ، یک `` را در پیوند Markdown قرار دهید تا نماد "پیوند خارجی" نشان داده شود.

  • [GitHub](https://github.com/tensorflow/docs) GitHub را تولید می کند

پارامترهای کوئری URI را در پیوند وارد نکنید:

  • استفاده از: <a href="https://www.tensorflow.org/guide/data">https://www.tensorflow.org/guide/data</a>
  • نه: <a href="https://www.tensorflow.org/guide/data?hl=en">https://www.tensorflow.org/guide/data?hl=en</a>

تصاویر

توصیه در بخش قبل برای پیوند به صفحات است. تصاویر به گونه ای متفاوت مدیریت می شوند.

به طور کلی، شما نباید تصاویر را بررسی کنید، و در عوض تیم TensorFlow-Docs را به روابط عمومی خود اضافه کنید و از آنها بخواهید که تصاویر را در tensorflow.org میزبانی کنند. این کمک می کند تا اندازه مخزن خود را پایین نگه دارید.

اگر تصاویر را به مخزن خود ارسال می کنید، توجه داشته باشید که برخی از سیستم ها مسیرهای نسبی به تصاویر را مدیریت نمی کنند. ترجیح می دهید از یک URL کامل که به مکان نهایی تصویر در tensorflow.org اشاره می کند استفاده کنید.

لینک های API زمانی که سایت منتشر می شود تبدیل می شوند. برای پیوند به صفحه مرجع API یک نماد، مسیر نماد را در بکتیک ها قرار دهید:

مسیرهای کامل به جز مسیرهای طولانی کمی ترجیح داده می شوند. مسیرها را می توان با حذف اجزای مسیر پیشرو به اختصار مشخص کرد. مسیرهای جزئی به پیوند تبدیل می شوند اگر:

  • حداقل یکی وجود دارد . در مسیر، و
  • مسیر جزئی در پروژه منحصر به فرد است.

مسیرهای API برای هر پروژه با یک API پایتون منتشر شده در tensorflow.org پیوند داده شده است. شما به راحتی می توانید با قرار دادن نام های API با بکتیک به چندین زیر پروژه از یک فایل پیوند دهید. به عنوان مثال:

برای نمادهایی با نام مستعار مسیرهای متعدد، ترجیح کمی برای مسیری وجود دارد که با صفحه API در tensorflow.org مطابقت دارد. همه نام های مستعار به صفحه صحیح هدایت می شوند.

ریاضی در Markdown

هنگام ویرایش فایل‌های Markdown می‌توانید از MathJax در TensorFlow استفاده کنید، اما به نکات زیر توجه کنید:

  • MathJax به درستی در tensorflow.org رندر می شود.
  • MathJax به درستی در GitHub رندر نمی شود.
  • این نماد می تواند برای توسعه دهندگان ناآشنا آزاردهنده باشد.
  • برای ثبات ، tensorflow.org از قوانین Jupyter/Colab پیروی می کند.

از $$ در اطراف یک بلوک از MathJax استفاده کنید:

$$
E=\frac{1}{2n}\sum_x\lVert (y(x)-y'(x)) \rVert^2
$$

E=12nx(y(x)y(x))2

عبارات MathJax درون خطی را با $ ... $ بپیچید :


This is an example of an inline MathJax expression: $ 2 \times 2 = 4 $

این نمونه ای از عبارت MathJax درون خطی است: 2×2=4

جداکننده های \\( ... \\) برای ریاضیات درون خطی نیز کار می کنند، اما فرم $ گاهی خواناتر است.

سبک نثر

اگر می‌خواهید بخش‌های قابل توجهی از مستندات روایت را بنویسید یا ویرایش کنید، لطفاً راهنمای سبک مستندسازی برنامه‌نویس Google را بخوانید.

اصول سبک خوب

  • املا و دستور زبان را در مشارکت خود بررسی کنید. اکثر ویرایشگرها دارای غلط‌گیر املا هستند یا افزونه‌های غلط‌گیری املا را در دسترس دارند. همچنین می‌توانید متن خود را در Google Doc یا سایر نرم‌افزارهای سند بچسبانید تا املا و گرامری قوی‌تر را بررسی کنید.
  • از صدای معمولی و دوستانه استفاده کنید. مستندات TensorFlow را مانند یک مکالمه بنویسید - گویی با شخص دیگری صحبت می کنید. از لحن حمایتی در مقاله استفاده کنید.
  • از سلب مسئولیت، نظرات و قضاوت های ارزشی خودداری کنید. کلماتی مانند "به راحتی"، ​​"فقط"، و "ساده" مملو از فرضیات هستند. ممکن است چیزی برای شما آسان به نظر برسد، اما برای شخص دیگری سخت باشد. سعی کنید تا حد امکان از این موارد اجتناب کنید.
  • از جملات ساده و دقیق و بدون اصطلاحات پیچیده استفاده کنید. جملات مرکب، زنجیره بندها و اصطلاحات خاص مکان می توانند درک و ترجمه متن را سخت کنند. اگر بتوان یک جمله را به دو قسمت تقسیم کرد، احتمالاً باید. از نقطه ویرگول اجتناب کنید. در صورت لزوم از لیست های گلوله ای استفاده کنید.
  • زمینه را فراهم کنید. بدون توضیح از اختصارات استفاده نکنید. پروژه های غیر TensorFlow را بدون پیوند به آنها ذکر نکنید. توضیح دهید که چرا کد به شکلی که هست نوشته شده است.

راهنمای استفاده

عملیات

در فایل‌های نشانه‌گذاری، وقتی می‌خواهید نشان دهید که یک op چه چیزی را برمی‌گرداند، به جای علامت مساوی از # ⇒ استفاده کنید.

# 'input' is a tensor of shape [2, 3, 5]
tf.expand_dims(input, 0)  # ⇒ [1, 2, 3, 5]

در نوت‌بوک‌ها، به‌جای افزودن نظر، نتیجه را نمایش دهید (اگر آخرین عبارت در سلول نوت‌بوک به متغیری اختصاص داده نشود، به‌طور خودکار نمایش داده می‌شود.)

در API اسناد مرجع ترجیح می دهند از doctest برای نمایش نتایج استفاده کنند.

تانسورها

وقتی به طور کلی در مورد یک تانسور صحبت می کنید، کلمه تانسور را با حروف بزرگ ننویسید. وقتی در مورد شی خاصی صحبت می کنید که به یک op ارائه شده یا از آن برگردانده شده است، باید کلمه Tensor را با حروف بزرگ بنویسید و بکتیک هایی را در اطراف آن اضافه کنید زیرا در مورد یک شی Tensor صحبت می کنید.

از کلمه Tensor (جمع) برای توصیف چندین شی Tensor استفاده نکنید، مگر اینکه واقعاً در مورد یک شی Tensors صحبت کنید. در عوض، بگویید «لیست (یا مجموعه) اشیاء Tensor ».

از کلمه شکل برای جزئیات محورهای یک تانسور استفاده کنید و شکل را در پرانتز مربع با تیک نشان دهید. به عنوان مثال:


If `input` is a three-axis `Tensor` with shape `[3, 4, 3]`, this operation
returns a three-axis `Tensor` with shape `[6, 8, 6]`.

همانطور که در بالا گفته شد، هنگام صحبت در مورد عناصر شکل Tensor ، "محور" یا "شاخص" را به "بعد" ترجیح دهید. در غیر این صورت به راحتی می توان "بعد" را با بعد یک فضای برداری اشتباه گرفت. یک "بردار سه بعدی" دارای یک محور به طول 3 است.