קובץ:Gaussianbeam fieldamplitude wb.png

תוכן הדף אינו נתמך בשפות אחרות.
מתוך ויקיפדיה, האנציקלופדיה החופשית

Gaussianbeam_fieldamplitude_wb.png(600 × 300 פיקסלים, גודל הקובץ: 24 ק"ב, סוג MIME‏: image/png)

ויקישיתוף זהו קובץ שמקורו במיזם ויקישיתוף. תיאורו בדף תיאור הקובץ המקורי (בעברית) מוצג למטה.

תקציר

תיאור
English: Drawing of the field amplitude of a Gaussian beam, white on black.
תאריך יצירה
מקור נוצר על־ידי מעלה היצירה
יוצר Geek3
גרסאות אחרות


 
. Matplotlib עם‎‎ נוצרה ה PNG תמונת מפת סיביות

Source Code

The image is created by the following python source-code. Requirements:


Python Matplotlib source code
#!/usr/bin/env python
# -*- coding: utf8 -*-

'''
Copyright (C) 2015 Geek3, Wikimedia Foundation

This program is free software; you can redistribute it and/or modify
it under the terms of the GNU General Public License as published by
the Free Software Foundation; either version 2 of the License, or
(at your option) any later version.

This program is distributed in the hope that it will be useful,
but WITHOUT ANY WARRANTY; without even the implied warranty of
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
GNU General Public License for more details.

You should have received a copy of the GNU General Public License
along with this program; if not, write to the Free Software
Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.
'''

from math import *
import scipy
from PIL import Image

w = 600
h = 300
image = scipy.zeros((h, w))


lambda_px = 24.
w0 = 24.

def E(r, z, w0):
    z0 = pi * w0**2 / lambda_px
    w = w0 * sqrt(1. + (z / z0)**2)
    k = 2. * pi / lambda_px
    R = z * (1. + (z0 / z)**2)
    gouy = atan(z / z0)
    E = w0 / w
    E *= e ** (-(r/w)**2)
    E *= e ** (-1j * k * r**2 / (2 * R))
    E *= e ** (1j * (gouy - k * z))
    return E


for y in range(h):
    for x in range(w):
        z = (x + 0.5) - w / 2.0
        r = -(y + 0.5) + h / 2.0
        EE = E(r, z, w0)
        image[y, x] = 0.5 * abs(EE) + 0.5 * EE.imag


# write image to file
image_file = Image.new('L', (w, h))
for y in range(h):
    for x in range(w):
        c = int(2**8 * image[y, x])
        image_file.putpixel((x, y), c)
image_file.save('gaussianbeam_fieldamplitude_wb.png', 'PNG')

רישיון

אני, בעל זכויות היוצרים על היצירה הזאת, מפרסם אותה בזאת תחת הרישיונות הבאים:
GNU head מוענקת בכך הרשות להעתיק, להפיץ או לשנות את המסמך הזה, לפי תנאי הרישיון לשימוש חופשי במסמכים של גנו, גרסה 1.2 או כל גרסה מאוחרת יותר שתפורסם על־ידי המוסד לתוכנה חופשית; ללא פרקים קבועים, ללא טקסט עטיפה קדמית וללא טקסט עטיפה אחורית. עותק של הרישיון כלול בפרק שכותרתו הרישיון לשימוש חופשי במסמכים של גנו.
w:he:Creative Commons
ייחוס
הקובץ הזה מתפרסם לפי תנאי רישיון קריאייטיב קומונז ייחוס 3.0 לא מותאם.
הנכם רשאים:
  • לשתף – להעתיק, להפיץ ולהעביר את העבודה
  • לערבב בין עבודות – להתאים את העבודה
תחת התנאים הבאים:
  • ייחוס – יש לתת ייחוס הולם, לתת קישור לרישיון, ולציין אם נעשו שינויים. אפשר לעשות את זה בכל צורה סבירה, אבל לא בשום צורה שמשתמע ממנה שמעניק הרישיון תומך בך או בשימוש שלך.
הנכם מוזמנים לבחור את הרישיון הרצוי בעיניכם.

כיתובים

נא להוסיף משפט שמסביר מה הקובץ מייצג

פריטים שמוצגים בקובץ הזה

מוצג

היסטוריית הקובץ

ניתן ללחוץ על תאריך/שעה כדי לראות את הקובץ כפי שנראה באותו זמן.

תאריך/שעהתמונה ממוזערתממדיםמשתמשהערה
נוכחית22:05, 12 ביולי 2015תמונה ממוזערת לגרסה מ־22:05, 12 ביולי 2015‪300 × 600‬ (24 ק"ב)Geek3gaussian beam plot

אין בוויקיפדיה דפים המשתמשים בקובץ זה.