Category Archives: programming

วิทย์ม.ต้น: Machine Learning ใน 5 นาที, ที่ฝึก ML, คำสอนปิดม.ต้น

วิทย์โปรแกรมมิ่งวันศุกร์สัปดาห์นี้ เด็กม.3 ได้ดูคลิปการสั่งให้คอมพิวเตอร์เรียนรู้จากตัวอย่าง (machine learning หรือ ML) ได้พิมพ์ตามคลิปนี้ครับ:

ผมเล่าให้ฟังว่าถ้าเรามีข้อมูลตัวอย่างเยอะๆดีๆเราก็สามารถให้คอมพิวเตอร์เรียนรู้ด้วยเทคนิคด้าน machine learning เพื่อช่วยทำงานต่างๆให้เราได้ ยกตัวอย่างเช่นอาจช่วยวินิจฉัยโรค ช่วยรู้จักหน้าคน รู้จักคัดตัวอย่างผลไม้ ตรวจหาวัชพืช แยกแยะแมลงมีประโยชน์และมีโทษ ช่วยวาดรูป ช่วยแต่งเพลง ฯลฯ โดยตัวอย่าง (ที่ไม่สมจริง) ที่ผมลองพิมพ์ให้ดูก็เช่นแยกระหว่างไข้หวัดใหญ่และโควิด-19:

ผมแนะนำให้เด็กๆไปศึกษาวิธีบอกให้คอมพิวเตอร์ช่วยงานด้านนี้ โดยใช้เวลาว่างเข้าไปเรียนรู้ที่ https://www.kaggle.com/learn/overview

เนื่องจากเด็กๆม.สามจะกระจายไปตามโรงเรียนต่างๆไม่ได้เรียนกับผมแล้วผมฝากข้อแนะนำสุดท้ายไว้ว่าให้ฝึกฝนเพื่อทำงานร่วมกับเครื่องจักรและโปรแกรมฉลาดๆให้ความสามารถของตนทวีคูณเป็นสิบเป็นร้อยเท่า อย่ารอให้คนอื่นใช้เครื่องจักรและโปรแกรมฉลาดๆมาแข่งกับเราก่อนเพราะเราจะเดือดร้อน และเมื่อเรียนคณิตศาสตร์ม.ปลายแล้วไม่รู้ว่าจะเรียนไปทำอะไรนอกจากสอบ ให้อ่านหนังสือ “คเณิร์ตศาสตร์” ที่ผมแจกไปให้

วิทย์ม.ต้น: Birthday Paradox ต่อ

วิทย์โปรแกรมมิ่งวันศุกร์นี้ เด็กๆม.3 เขียนโปรแกรมไล่ดูว่าต้องมีคนสักกี่คนอยู่ด้วยกันแล้วความน่าจะเป็นที่จะมีคนวันเกิดซ้ำกันบ้างเกิน 50% พบว่าต้องมีคน 23 คนครับ

หน้าตาฟังก์ชั่นคำนวณความน่าจะเป็นที่คน k คนจะไม่มีวันเกิดซ้ำกันเลย และมีวันเกิดซ้ำกันบ้างจะเป็นประมาณนี้ครับ:

เราวาดกราฟดูด้วย matplotlib ได้ดังนี้ครับ:

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

เช่นสมมุติว่ามีคนหลายคนใส่นาฬิกาโดยที่ไม่ได้ตั้งกันมาให้ตรงกับเวลามาตรฐานก่อน เข็มวินาทีของแต่ละคนก็อาจจะชี้เลขจาก 0 ถึง 59 ถ้าเราสมมุติว่าโอกาสที่เข็มชี้เลขต่างๆด้วยความน่าจะเป็นเท่าๆกัน เราก็สามารถหาโอกาสที่คน k คนจะมีเข็มวินาทีซ้ำกันอยู่ได้ด้วยฟังก์ชั่น prob_some_repeat(60, k) เราจะพบว่าเมื่อมีคน 10 คน ความน่าจะเป็นที่มีเข็มชี้ไปที่วินาทีซ้ำๆกันบ้างจะมากกว่า 50% ครับ

ด้วยคณิตศาสตร์ระดับสูงขึ้นไป เราจะสามารถคำนวณได้ว่าถ้ามีของให้เลือก N ชิ้น แล้วมีคน k คนมาเลือกสุ่มๆโดยโอกาสเลือกของแต่ละชิ้นเท่าๆกัน ความน่าจะเป็นที่จะมีการเลือกซ้ำจะมีค่า 50% เมื่อ k มีค่าประมาณ 1.2 √N เท่านั้นครับ

การบ้านคือให้เด็กๆไปทดลองหาว่าสำหรับของ 10, 10^2, 10^3, 10^4, 10^5, 10^6 ชิ้นต้องมีคนกี่คนเลือกถึงมีโอกาสเลือกซ้ำกันประมาณ 50% และใกล้กับค่า 1.2 √N ไหม

วิทย์ม.ต้น: Leap Year, Birthday Paradox, The Monty Hall Problem, ฝึก TrackeR

วิทย์โปรแกรมมิ่งวันศุกร์นี้ เด็กๆม.3 ดูเฉลยการบ้านเรื่องหาวันที่เป็น palindrome คืออ่านกลับหลังก็เหมือนอ่านปกติเช่นวันที่ 2020-02-02 ครับ ในการบ้านเด็กๆต้องไปหาวิธีหาว่าปีไหนมี 366 วัน (เป็น leap year) ด้วย กฎเกณฑ์คือดูปีเป็น ค.ศ. แล้วดูว่าถ้าปีหารด้วย 4 ลงตัวก็เป็น leap year แต่ถ้าหารด้วย 100 ลงตัวก็ไม่นับเป็น leap year แต่ถ้าหารด้วย 400 ลงตัวก็นับเป็น leap year

สาเหตุที่ต้องมีกฎเกณฑ์แบบนี้เพราะว่าโลกใช้เวลาประมาณ 365.242189 วัน (หรือ 365 วัน 5 ชั่วโมง 48 นาที 45 วินาที) คือในหนึ่งปีจะมีวันเกิน 365 วันไปเกือบๆ 1/4 วัน เราจึงต้องพยายามชดเชยประมาณเกือบๆทุกๆ 4 ปี

วิธีเขียนฟังก์ชั่นหา leap year ก็จะมีหน้าตาประมาณนี้ครับ:

ถ้าเขียนตามวิธีที่ Wikipedia แสดงไว้ก็จะมีหน้าตาแบบนี้:

เช็คดูว่าปีต่างๆมีจำนวนวันอย่างที่คาดหรือเปล่า ในสองพันปีมี leap year 485 ปีใช่ไหม และฟังก์ชั่น is_leap_year และ is_leap_year1 ทำงานเหมือนกันใช่ไหม:

ต่อจากนั้นผมก็แนะนำให้เด็กๆม. 3 รู้จักกับ Birthday Paradox ที่สมมุติว่าทุกปีมี 365 วัน และแต่ละวันมีคนเกิดเท่าๆกัน ดังนั้นถ้ามีคนเกิน 365 คนก็ต้องมีวันเกิดซ้ำกันแน่ๆ ถ้ามีคนเดียวก็ไม่มีวันเกิดซ้ำกันได้ ถ้ามีสองคนโอกาสที่วันเกิดจะซ้ำกันคือ 1/365 คำถามก็คือต้องมีคนสักกี่คนถึงจะมีโอกาสมีวันเกิดซ้ำกันประมาณ 50%

เด็กๆเดากันว่าอาจจะต้องมีสัก 100 คน เราจึงเขียนโปรแกรมคำนวณความน่าจะเป็นที่จะมีวันเกิดซ้ำกันถ้ามีคน k คนครับ

วิธีคำนวณง่ายที่สุดคือให้สังเกตว่าถ้าให้ p = ความน่าจะเป็นที่จะมีวันเกิดซ้ำกันในกลุ่มคน k คน และ q = ความน่าจะเป็นที่ไม่มีวันเกิดซ้ำกันเลยในกลุ่มคน k คนแล้ว จะได้ว่า p = 1 – q แล้วก็ไปคำนวณ q กันก่อน

สำหรับ k = 1 คน, q = 1 เพราะคน 1 คนไม่สามารถมีวันเกิดซ้ำกับใคร
สำหรับ k = 2 คน, q = 364/365 คือคนที่สองต้องเกิดไม่ซ้ำกับคนแรก
สำหรับ k = 3 คน, q = 364/365 x 363/365 คือคนที่สามก็ต้องไม่ซ้ำกับคนที่สองด้วย
ถ้าไล่ไปเรื่อยๆ สำหรับ k คน, q จะเท่ากับ (365-k+1)/365 คูณกับ q ของ k-1 คน

พอคำนวณ q เสร็จเราก็คำนวณ p จาก p = 1 – q

ให้เด็กๆม.3 ไปทำเป็นการบ้านคือเขียนโปรแกรมคำนวณ p, q และตอบคำถามว่าต้องมีคนสักกี่คนถึงจะมีโอกาสวันเกิดซ้ำกันบ้างประมาณ 50% ครับ

นอกจากนี้ผมยังให้เด็กๆม. 3 รู้จัก The Monty Hall problem (แปลเป็นภาษาไทยที่นี่) ด้วยครับ สถานการณ์เป็นแบบนี้:

สมมติว่าผู้เล่นเกมโชว์มีประตูสามบานให้เลือก หลังประตูบานหนึ่งจะมีรางวัลอยู่ (มักจะบรรยายว่าเป็นรถยนต์) ส่วนหลังประตูบานที่เหลือไม่มีรางวัล (มักจะบรรยายว่ามีแพะอยู่หลังประตู) ผู้เล่นเลือกประตูหนึ่งบาน (สมมติว่าเรียกว่าประตูบานที่ 1) เมื่อผู้เล่นเลือกแล้ว พิธีกรซึ่งรู้ว่าหลังประตูแต่ละบานมีรางวัลหรือไม่ จะเปิดประตูอีกบานหนึ่งซึ่งไม่มีรางวัล (สมมติว่าเป็นประตูบานที่ 3) หลังจากนั้น พิธีกรจะให้โอกาสผู้เล่นในการเปลี่ยนไปเลือกประตูอีกบานหนึ่งที่ไม่ได้เลือกในตอนแรก (บานที่ 2) คำถามคือ การเปลี่ยนไปเลือกประตูที่ไม่ได้เลือกตอนแรก จะทำให้มีความน่าจะเป็นในการได้รางวัลมากขึ้นหรือไม่

จาก https://th.wikipedia.org/wiki/ปัญหามอนตี_ฮอลล์

คนส่วนใหญ่จะคิดว่าเปลี่ยนหรือไม่เปลี่ยนประตูก็น่าจะมีโอกาสชนะเท่าๆกัน แต่จริงๆไม่ใช่อย่างนั้นครับ

ผมให้เด็กๆดูคลิปนี้ช่วงแรกก่อนเฉลย:

และการบ้านของเด็กๆคือไปเขียนโปรแกรมจำลองการเล่นเกมนี้เป็นพันๆครั้ง ดูว่าถ้าเปลี่ยนประตูจะมีโอกาสชนะเท่าไร ถ้าไม่เปลี่ยนประตูจะมีโอกาสชนะเท่าไรครับ

สำหรับเด็กม.1 ผมให้หัดใช้โปรแกรม Tracker เพื่อวัดระยะทาง ความเร็ว ความเร่งในวิดีโอคลิปต่างๆของเรากันครับ เป็นโปรแกรมฟรี open source และมีบน Windows, macOS, Linux

ผมเคยบันทึกตัวอย่างการใช้ไว้ที่นี่ครับ:

คราวนี้เด็กๆวัดการสั่นของตุ้มน้ำหนักที่ผูกกับหนังยางต่อกันสามเส้น และแบบหนังยางต่อกัน 6 เส้นครับ ให้สังเกตว่าคาบการสั่นต่างกันอย่างไร อันไหนใช้เวลามากกว่าในการสั่นหนึ่งรอบ หน้าตาโปรเจ็คเป็นแบบนี้ครับ: