แนวโน้มฮาร์ดแวร์ที่กำลังต้องการการประมวลผลแบบขนานมากขึ้นเรื่อยๆ ในทุกวันนี้มีปัญหาอย่างหนึ่งคือเครื่องมีที่ใช้พัฒนานั้นยังแย่อยู่มาก และนักพัฒนาเองก็บ่นกันเสมอว่าการพัฒนาซอฟต์แวร์แบบขนานนั้นยากเกินไป ไมโครซอฟท์ก็ปล่อยภาษา Axum ที่ทำงานอยู่บน .NET Framework มาเป็นทางเลือกให้นักพัฒนากัน
ภาษา Axum นั้นโดยสรุปแล้วเป็นภาษาที่ฝังเอาโครงสร้างการส่งข้อมูลระหว่าง Thread ที่ในภาษานี้เรียกว่า Agent เข้าไว้เป็นส่วนหนึ่งของตัวภาษาทำให้การติดต่อระหว่างกันทำได้ค่อนข้างเป็นธรรมชาติกว่าการใช้ไลบรารีเสริมเช่นภาษาอื่นๆ
ภาษานี้ยังอยู่ใน MSDN Development Labs ผมยังไม่แน่ใจนักว่าไมโครซอฟท์เอาจริงกับภาษานี้มากแค่ไหน แต่โดยส่วนตัวแล้วผมมองว่าการขยายภาษาเดิมให้รองรับ Message Queue น่าจะทำได้เหมือนกัน และอาจจะเป็นธรรมชาติกับโปรแกรมเมอร์มากกว่า
ที่มา - Microsoft Axum
on
แหล่มเลยย
cloverink Tue, 12/05/2009 - 17:11
แหล่มเลยย
น่าสนใจมา
btssky Tue, 12/05/2009 - 17:33
น่าสนใจมากครับ
เดี๋ยวมัน
ezy Tue, 12/05/2009 - 17:58
เดี๋ยวมันคงไปรวมตัวกับ C# กับ VB.net แหละมั้ง?
ezybzy.info blog
ผมว่าไม่ต
nuntawat Tue, 12/05/2009 - 18:56
In reply to เดี๋ยวมัน by ezy
ผมว่าไม่ต้องไปรวม ไวยากรณ์และการเขียนก็ดูคล้าย C# มากแล้วครับ หุหุ ... กะว่าถ้างานวิจัยที่ทำเสร็จในระดับหนึ่งจะลองเอา Axum มาใช้ดู เพราะดูจะประยุกต์ได้กับงานที่ผมทำอยู่
น่าสนใจอย
NgOrXz Tue, 12/05/2009 - 18:03
น่าสนใจอย่างที่สุด
©NgOrXz™®
แมนเชสเตอร์ยูไนเต็ด เก่งที่สุดในโลก
แม้มัลติค
Mayarine Tue, 12/05/2009 - 18:23
แม้มัลติคอร์วางตลาดมาหลายปีแล้วแต่โปรแกรมส่วนใหญ่ก็ยังใช้singlecore
สงสัยต้องรอCpu6คอร์วางขายในตลาดmainsteamก่อนมั้ง โปรแกรมที่รองรับมัลติคอร์ถึงจะแพร่หลาย
จริงๆแล้ว
m3rlinez Tue, 12/05/2009 - 19:56
จริงๆแล้วตอนนี้ก็มีความพยายามทำ Microsoft Parallel Extensions to .NET Framework 3.5 นะครับ ลองดูโค้ดตัวอย่างง่ายๆ (ใน C#)
System.Threading.Parallel.For(0, maxNum + 1, x => IsPrime(x))
เป็นการกระจายการหา prime ในช่วง 0 ถึง maxNum
ผมว่าแค่นี้น่าจะเพียงพอกับความต้องการ Dev ทั่วไป o__o' เพราะเท่าที่ลองพยายามไปดู Parallel Algorithm มารู้สึกว่าเข้าใจยากไปหน่อย แล้วไม่รู้จะเอามาใช้กับปัญหาทั่วๆไปที่ไม่ใช่ scientific ตอนไหน (http://www.cs.cmu.edu/~scandal/nesl/algorithms.html)
เอ่อ
kittipat Wed, 13/05/2009 - 05:05
In reply to จริงๆแล้ว by m3rlinez
เอ่อ แบบนั้นนี่ OpenMP ง่ายกว่าเยอะนะเนี่ย
Parallel algorithm จริงๆมันก็คือ divide and conquer นะ แล้วก็จริงๆแล้วอะไรก็ตามที่มันต้องวนซ้ำก็ทำ parallel ได้แทบทั้งหมดนะ จะได้มากน้อยแค่ไหนก็อีกเรื่อง อย่างตรวจคำผิดนี่ก็ทำ parallel ได้
จริงๆแล้ว
m3rlinez Thu, 14/05/2009 - 02:52
In reply to เอ่อ by kittipat
จริงๆแล้วมีปัญหาวนซ้ำ "จำนวนมาก" ที่ทำ parallel ไม่ได้ครับ โดยเฉพาะพวกการวนซ้ำที่ต้องอาศัยผลลัพธ์จากสเตปก่อนหน้า เช่นพวกการคำนวณซ้ำๆเพื่อหาค่าของ Pi
ส่วน OpenMP ไม่เคยลอง ถ้าเป็นไปได้อยากให้ลองเอาโค้ดส่วนที่เป็นการแยกงาน maxNum งานออกไปทำให้ดูหน่อย ผมรู้สึกว่าไอ่ Parallel Extension ข้างบนทำได้ง่ายมากแล้ว ถ้ามีง่ายกว่านี้อีกคงน่าตื่นเต้นน่าดู o__o''
จริงอยู่ว
kittipat Thu, 14/05/2009 - 06:29
In reply to จริงๆแล้ว by m3rlinez
จริงอยู่ว่าปัญหาจำนวนมากทำ parallel (ยัง)ไม่ได้ ดูแล้วมืดมนหนทางไม่มี แต่ก็อาจจะมีอัจฉริยะซักคนในอนาคตแก้ได้ (เหมือนปัญหา P=NP หรือเปล่า)
โปรแกรมข้างบนแบบ OpenMP น่าจะประมาณนี้ ถ้าตีความ code ไม่ผิด และ IsPrime เป็น function ธรรมดา (ออกตัวก่อนว่าไม่เคยเขียนเอง เคยเห็นแต่คนเอา source มา compile กันให้ดูจะๆ)
#pragma omp parallel for
for (x = 0; x < N; x++)
isPrime(x);
จริงๆก็ไม่ต่างกับข้างบนเท่าไหร่ ดูจะยาวกว่าด้วยซ้ำ แต่ว่าใช้ construction ที่คุ้นเคย ไม่ต้องมานั่งแปลง code แค่แปะ #pragma ไปก็เรียบร้อย
แต่เวลา run OpenMP นี่ถ้าจำไม่ผิดต้องใส่ parameter เอง ลำบากก็ตรงนั้นแหละ
อันนี้ของแถม PRIMES is in P ไปเจอมาระหว่างหาข้อมูลมาตอบ (ยังไม่ได้อ่าน แต่น่าสนใจดี)
ป.ล. เคยทำโปรแกรม parallel เกือบปีเลยรู้อะไรมาบ้างนิดหน่อย (senior project, CP31 :)
ชัดเจนครั
m3rlinez Thu, 14/05/2009 - 13:42
In reply to จริงอยู่ว by kittipat
ชัดเจนครับ ขอบคุณครับ :)
เคสทั่วไป
wiennat Wed, 13/05/2009 - 22:46
In reply to จริงๆแล้ว by m3rlinez
เคสทั่วไปก็อย่างเช่น Rip หนังจาก DVD แล้วแปลงเป็น avi นี่มันเป็น scientific รึเปล่าอะ
onedd.net
ไม่รู้ว่า
m3rlinez Thu, 14/05/2009 - 03:20
In reply to เคสทั่วไป by wiennat
ไม่รู้ว่างาน Encoding จริงๆแล้วกลไกมันทำยังไง แต่ถ้ามันแบ่งส่วนได้ชัดเจน เช่น ให้ core นึง encode ครึ่งเรื่องแรก อีก core ทำครึ่งหลัง มันก็เป็นงานง่ายๆที่ การแตก Thread ออกมาแยกกันทำ หรือการใช้ extension ง่ายๆอย่าง Parallel.for ก็ทำให้เร็วขึ้น(มาก)ได้แล้ว ถ้าเป็นตามนี้ผมก็มองว่ามัน - ไม่เป็น scientific
ส่วนปัญหาที่มันหั่นไปทำไม่ได้ง่ายๆแบบข้างบน (หรือที่ผมเรียกว่า scientific) - ผมก็พยายามทำความเข้าใจอยู่ว่าจะเอา parallel algorithm มาทำให้เร็วขึ้นได้อย่างไร? ซึ่งจากการเข้าไปดู library แห่งหนึ่ง (ตามลิงค์ด้านบน) ก็พบว่าล้วนแล้วแต่เป็นปัญหา "แปลกๆ" ทั้งสิ้น
ผมจึงคิดว่า ภาษาใหม่ที่จัดการกับกลุ่มปัญหาดังกล่าวได้ มันไม่น่าจะมีผลอะไรกับ Dev(ส่วนใหญ่) เท่าไหร่ extension ของภาษาเหมือนที่คุณ lew บอกน่าจะอนาคตสดใสกว่า
ปล. ใครตอบคนสุดท้ายชนะนะครับพี่วีน :P
มันทำไม่ง
wiennat Thu, 14/05/2009 - 11:52
In reply to ไม่รู้ว่า by m3rlinez
มันทำไม่ง่ายขนาดนั้นอะ เพราะว่ารอยต่อระหว่างครึ่งแรกกับครึ่งหลังมันก็มีผลถูกมั้ยล่ะ
สรุปว่ายังงอยู่ว่า scientific กับทั่วๆไปในทีนี้มีนิยามหรือมีข้อแตกต่างกันอย่างไร
onedd.net
ผมคิดว่าม
m3rlinez Thu, 14/05/2009 - 13:29
In reply to มันทำไม่ง by wiennat
ผมคิดว่ามันคงแยกได้ไม่เด็ดขาดหรอกครับ เหมือนกับ "งานวิจัย" กับ "โปรแกรมประยุกต์" ของที่อยู่ตรงขอบก็มีเยอะ :)
เรื่อง scientific ผมก็ีิคิดว่าขอบมันไ่ม่ชัด แต่มันมักจะ
ลองนึกถึง
wiennat Thu, 14/05/2009 - 15:13
In reply to ผมคิดว่าม by m3rlinez
ลองนึกถึงว่าทำ sort แบบขนานดูสิ มันจะเร็วขึ้นมั้ยอะ merge sort ก็ได้ คิดง่ายดี
onedd.net
มันก็คงเร
m3rlinez Thu, 14/05/2009 - 18:56
In reply to ลองนึกถึง by wiennat
มันก็คงเร็วขึ้นครับ จริงๆแล้วมีอัลกอริทึมที่ออกแบบมาเพื่อทำ sort แบบขนานโดยเฉพาะด้วย แต่ผมคิดว่าเรื่องดังกล่าวมันเป็นเรื่อง scientific เวลาเราทำ Array.Sort กันปกติก็ไม่ได้สนใจว่ากลไกข้างล่างมันเป็นยังไง รู้แค่ logic สำหรับการ compare แล้วก็ complexity ของ sort ที่ framework มัน implement มาแล้วก็พอ
สงสัย Scientific
wiennat Sat, 16/05/2009 - 00:13
In reply to มันก็คงเร by m3rlinez
สงสัย Scientific เราจะไม่เท่ากัน ฮะๆๆๆ
onedd.net
คิดตลกๆ
paepod Tue, 12/05/2009 - 20:23
คิดตลกๆ ขอแบบว่าแบบปกติ(ปัจจุบัน)แต่ว่า .NET Framwork ทำเป็น Parallel ให้อัตโนมัติ Microsoft จัดมา (ขำๆ)
ทำตัวเป็น
b98se Tue, 12/05/2009 - 22:57
In reply to คิดตลกๆ by paepod
ทำตัวเป็น Framwork ทั้งที ความจริงเรื่องพันนี้น่าจะช่วยเราจัดการด้วยน่ะ หรือว่ามันลึกซึ้งกว่านั้น
b98se.in.th : โค้ดมันส์ สคริปมึน โปรแกรมมั่ว
ดูก็น่าจะ
kittipat Wed, 13/05/2009 - 05:16
ดูก็น่าจะง่ายกว่า MPI นะครับ แต่ว่าขอแบบ OpenMP ก่อนน่าจะดีกว่านะ ถึง OpenMP มันจะไม่ได้รองรับการ parallel แบบพิสดารมาก แต่งานบางอย่างแค่เอา OpenMP ยัดเข้าไปก็เร็วขึ้นผิดหูผิดตาแล้ว
ผมเคยเห็น
teedech Thu, 14/05/2009 - 17:02
ผมเคยเห็นมีคนพยายามพัฒนา library บน .NET ที่มีความสามารถด้าน Concurrency สูงๆ ชื่อ Retlang ซึ่งได้แนวคิดมาจากภาษา Erlang (ที่เคยเป็นหัวข้อในงานสัมมนาของ Blognone มาแล้ว)----------------------------
VB.NET Programming