Nov 10 2009

Data Visualization

Category: Toolsm3rLinEz @ 00:17

gant_so 

ทุกวันนี้พวกเราทำงานกับข้อมูลจำนวนมาก มันเป็นศาสตร์ใหญ่ๆอย่างนึงเลยทีเดียวในเรื่องของวิธีการเอาข้อมูลมาแสดง ว่าการแสดงในรูปแบบไหนถึงจะทำให้ผู้ชมเข้าใจข้อมูลได้ง่ายที่สุด และสามารถ reveal feature บางอย่างที่ถ้าสังเกตจาก representation อย่างอื่นแล้วอาจจะมองไม่เห็น!

รูปด้านบนเกิดจากการเอาโพสต์จากบลอกภาษาอังกฤษของผมมาตัดคำแล้วเอามาทำเป็นต้นไม้ จะเห็นได้ขึ้นมาชัดระดับนึงว่า เวลาเราเขียนคำๆนึงแล้ว เรามักจะเอาคำอะไรมาต่อ (อื้มมมม น่าจับพวกเนื้อเพลงมาทำ คงฮาระดับนึง :P) อันนี้มีคนใจดีทำไว้ให้เล่น ที่ Many Eyes

อันนี้เป็นอีกรูปนึงที่ความถี่ของคำเยอะกว่ารูปแรกมาก (ใช้คำว่า I)

gant_i

จริงๆแล้วตัวเว็บมันยังมีรูปแบบในการ Visualize ให้เล่นอีกหลายแบบมาก รวมถึงรูปแบบข้อมูลที่เอา input ให้ระบบไปก็ยังมี 2 รูปแบบ ตัวอย่างข้อมูลที่เป็นโพสต์จากบลอกของผมเรียกว่า Free Text แต่ยังมีอีกแบบนึงที่เป็น Table ซึ่งทำให้สามารถนำเสนอข้อมูลที่มันสัมพันธ์กันซับซ้อนมากกว่า 1 มิติได้

ส่วนอันนี้เป็นอีกรูปแบบนึงที่เรียกว่า Phrase Net อันนี้จะเน้นการแสดงความสัมพันธ์ในระดับคำแทน เราสามารถเลือกได้ว่าให้ระบบแสดงความสัมพันธ์แบบไหน ตัวอย่างเช่น สัมพันธ์แบบเป็นวลีในรูปแบบ “A and B” หรือ “A’s B” หรือ “A of B” หรือ “A[space]B” อันที่เอามาให้ดูนี่เป็นแบบ “A[space]B” รู้สึกว่ารูปสวยดี (อันนี้เหมาะจะเอามาทำกับเนื้อเพลงมากกว่าอันข้างบนอีก ฮ่าๆ)

gant_pn

ส่วนอันนี้ชอบมาก! สวยกว่านั่งทำ Typography เองอีก โอ้ว!!! ใครโดนสั่งทำปกสมุดแล้วคิดอะไรไม่ออก เอาไอนี่ไปวางแก้ขัดได้เลย ~

gant_typo

สาขา ป.โท ที่ใกล้เคียงเรื่องพวกนี้ที่สุดน่าจะเป็นเรื่อง Human Computer Interaction (HCI) เคยอยากเรียนเหมือนกัน แต่จน .. เอ้ย! แต่โง่ …. เย้ยย! รู้สึกว่าถ้าไปเรียนก็คงสนุกดี (เข้าทาง) ชอบเรื่องพวกนี้มากๆเลย ถ้าไปเรียนก็อยากไปเรียน ”เพื่อความบันเทิง” อ่ะ (แต่คงยากจะเกิดเหตุการณ์แบบนั้นขึ้น –_-‘ ถ้ายังคงมีภาระชีวิตที่ต้องรับผิดชอบอยู่)

ใครสนใจก็ลองไปเล่นกันดู :)

Tags: , , ,

Sep 20 2009

Remote Debugging J2EE Application

Category: Java | Toolsm3rLinEz @ 12:04

ตั้งชื่อบลอกไม่ถูก คำศัพท์ Java มันเยอะจัด (J2EE, Web Container, Servlet, ...)

ฐานโค้ดที่ผมดูอยู่ที่ทำงานมันค่อนข้างใหญ่มาก เป็นไฟล์ Text ขนาดรวมกันเกือบ 20 MB ซึ่งจริงๆแล้วส่วนที่เราจะเข้าไปมองจริงๆมันก็ไม่ได้เยอะอะไรหรอกครับ แต่ปัญหาก็คือว่า เราจะหาส่วนที่เราต้องการมาได้ยังไงจากข้อมูลที่เยอะขนาดนั้น ??? คำตอบหนึ่งคือใช้โปรแกรมพวก Cross Referencing เช่น OpenGrok จะช่วยให้ค้นหาส่วนของโค้ดที่ต้องการได้ง่ายขึ้นเยอะเลย นอกจากนี้ OpenGrok ยังสนับสนุนการทำ index บน repository ของพวก SCM Tools ต่างๆเช่น SVN, Git และ Mercurial อีกด้วย

เข้าเรื่อง … ปัญหาที่ผมเจอคือ OpenGrok มันดันไม่โชว์ History ให้ ซึ่งหลังจากถามไปใน mailing-list ก็พบว่ามันเกิดจากการหาโปรแกรม hg (Mercurial) ไม่เจอใน PATH ผมลองมา reproduce ที่บ้านบน environment ที่เป็น Windows ก็ยังเจอปัญหาเดียวกันอยู่ เลยต้องหาวิธี Debug OpenGrok ตอนนั้นคิดๆไว้หลายวิธี

  • Build เฉพาะ Class ที่ทำหน้าที่ส่วนนั้นขึ้นมาใหม่ แล้วใส่ให้มันโหลดขึ้นก่อนใน CLASSPATH  .. อันนี้สุดท้ายก็ทำไม่ได้เพราะผม build เป็นไฟล์ๆไม่ได้มันติดพวก dependency เลยไม่รู้ว่าสรุปแล้วใช้วิธีนี้ได้ป่าว
  • อ่านวิธี Build OpenGrok จากเว็บมันแล้วลองตั้ง breakpoint ตรงส่วนที่เป็นปัญหา อ่านแล้ววิธีนี้น่าจะง่าย แต่เนื่องจากว่าตัว Container ที่ใช้มันเป็น Tomcat แต่ปกติ Netbeans มันจะติดมากับ Glassfish เลยเกิดความขี้เกียด config ขึ้นมาในบัดดล
  • ทำ Remote Debugging คือ start Tomcat ใหม่ให้มันรันแบบ Debug และเปิด port 7001 รอไว้ แล้วเอา Debugger เข้าไป attach … อันนี้ได้ผลครับ และง่ายมากด้วย แต่ต้อง build OpenGrok ได้น่ะ หลังจากตั้ง breakpoint ไว้แล้วปรากฎว่ามัน break จริงๆด้วยว่ะ! Watch + Evaluate ได้แทบทุกอย่างเลย

จริงๆ ASP.NET ก็มีของแบบนี้เหมือนกัน มันเหมาะมากเวลาเกิดปัญหากับ Application ใหญ่ๆที่การ Setup ให้เกิดปัญหาเดียวกันมันยาก ใช้แล้วก็รู้สึกว่า Java ก็ไม่เลวครับ : )

Java Options สำหรับ Start Tomcat

-Xdebug
-Djava.compiler=NONE
-Xrunjdwp:transport=dt_socket,server=y,suspend=n,address=7001

แล้วใช้ Netbeans attach เข้าไปที่ port 7001 ของ localhost

Tags: , , , , ,

Aug 26 2009

ลอง Mercurial

Category: Toolsm3rLinEz @ 01:39

หลังจาก Tweet ไปทำนองว่า “หลงรัก Hg เข้าแล้ว” นาย @teerapapc มันก็ทักไว้ตั้งแต่เมื่อวันก่อนว่าเด๋วคงได้เขียนบลอกแน่ ซึ่งก็เขียนจริงๆแต่ขอทิ้งระยะหน่อย เด๋วคำทำนายมันจะตรงไป อะแฮ่ม~!

หลังจากที่ผมอิดออดกับการเลือก Distributed Version Control System มาลองเล่นซักตัว จนเมื่อเร็วๆนี้เห็นข่าวว่า Google มัน supports Mercurial เพิ่มเรียบร้อยแล้ว (จากเดิมที่ support SVN อยู่แล้ว) โดย Google มีรายงานเหตุผลที่ Google เลือก Mercurial แต่ไม่เลือก Git ให้อ่านกันด้วย ผมอ่านแล้วเกิดความรู้สึกให้ไปเปรียบเทียบสองอย่างนี้กับ Emacs และ VIM ยังไงไม่ทราบ (ซึ่งผมเป็นสาวก VIM) คืออันแรกมัน customizable มากๆ แต่ก็ใช้ยากและ learning curve ชัน ส่วนอันที่สองมันค่อนข้างจะเรียนรู้ง่าย ถึงจะ features ไม่เยอะเท่าก็ตาม สุดท้ายผมเลยเลือกไปลอง Mercurial ตามรอยเท้าคุณ Google ซึ่งผลก็น่าประทับใจครับ :) มีเรื่องที่ชอบดังต่อไปนี้

  • รู้สึกว่าคำสั่งบน command line ตรงไปตรงมาและใช้ง่ายมากๆ จนรู้สึกว่าไม่ต้องมี GUI (พวก Tortoise) ก็ได้ล่ะมั้ง (จริงๆแล้วอาจจะเป็นเพราะช่วงนี้ใช้ cmd line บ่อยมากก็ได้)
  • หลายครั้ง GUI มันก็ช่วยให้เข้าถึงข้อมูลเร็วขึ้น ตัว Mercurial เองก็มี web server ย่อมๆ built-in มาด้วย เรียก hg serve –n “Gant Repo” แล้วก็เข้าไปดูเว็บที่ port 8000 ได้เลย ผมรู้สึกว่าไอเดียนี้เจ๋งมาก!
  • เอกสาร Tutorial และ Quick Start ที่เว็บของเค้าเขียนอ่านแล้วทำตามได้ง่ายๆ ผมอ่านแล้วรู้สึกไม่หนักสมองเท่าไหร่ อ่านนิดเดียวก็เริ่มสนุกกับของเล่นใหม่ได้แล้ว

ปล. Hg = Hydrogentum = Mercury เป็นตัวย่อที่เท่และตรงไปตรงมา สำหรับคนเคยเรียนเคมี และรู้จัก Mercurial มาก่อน

Tags:

Jul 14 2009

ควบคุมบราวเซอร์ด้วย WatiN

Category: .NET | Toolsm3rLinEz @ 23:11

วันนี้พยายามจะเขียนโปรแกรมให้ export ข้อมูลออกจาก web app ที่ทำงานตัวนึงอัตโนมัติ เขียนไปเขียนมา account โดนล็อค - -‘ แกว่งเท้าหาเสี้ยนชัดๆเลย

[Test]
public void SearchForWatiNOnGoogle()
{
using (IE ie = new IE("http://www.google.com"))
{
ie.TextField(Find.ByName("q")).TypeText("WatiN");
ie.Button(Find.ByName("btnG")).Click();

Assert.IsTrue(ie.ContainsText("WatiN"));
}
}

ใช้ง่ายเกินไปแล้ว!! สนใจเชิญที่ WatiN (สำหรับชาว .NET เท่านั้น – Web Application Testing in .NET - รุสึกจะมี WatiR ที่เป็นของ Ruby ด้วย)

มันเป็นเครื่องมือสำหรับให้พวก QA/Tester ใช้อ่ะครับ แต่คิดว่าถ้าจะเอาไปดัดแปลงทำ บอตโหวตคะแนน บอตลงทะเบียน หรืออะไรทำนองนี้ก็เอาไปทำได้ไม่ยากเลย

ข้อเสียคือใช้ได้กับ IE 6 7 8 เท่านั้น (Firefox อยู่ใน Roadmap) ถ้าอยากใช้กับ Firefox หรือ browser อื่นๆ ลองดู Selenium

ข้อเสียอีกอย่างคิดว่าคงเหมือนกับเครื่องมือทำนองนี้อื่นๆทั่วๆไป คือถ้าเมนูเป็น Flash เป็น Java Applet หรือเป็น ActiveX Object อะไรซักอย่าง มันจะทำให้เขียนโค้ดเข้าไป Automate ยาก (หรือทำไม่ได้) ขึ้นมาทันที

ปล. ต่อไปนี้จะพยายามเขียนบลอกให้สั้นๆ ได้ใจความมากขึ้น

Tags: , ,

Jul 1 2009

VIM แบบพื้นฐานมาก

Category: Toolsm3rLinEz @ 00:47

VIM

คงเคยรู้จัก vi และ emacs กันมาบ้างนะครับ ชื่อเสียงที่หนาหูเกี่ยวกับ editor สองตัวนี้คือมันใช้ยากกกกก

VIM หรือ vi-improved เป็น vi เวอร์ชันเพิ่มความสามารถครับ แล้วก็มีให้ดาวน์โหลดไปใช้ได้แทบทุก OS มันจะมีฟังก์ชันหล่อๆเพิ่มขึ้นมาที่ vi ไม่มี เท่าที่ผมเห็นว่าสำคัญมีอยู่สองสามอย่าง

  • Autocomplete อันนี้หล่อมากเลย ยอมรับ ทำได้หลายอย่าง เช่น
    • ชื่อไฟล์ หรือ path ไปยังไฟล์ สะดวกมากเวลาต้องเขียนไฟล์ที่มันต้องระบุ path
    • คำที่เคยพิมพ์มาแล้ว
    • keyword ในภาษาเขียนโปรแกรม โดยมันเป็น context-sensitive ด้วย (Omni-completion) อันนี้อาจจะต้องลง plug-in เพิ่ม
  • Multiple Tabs เปิด Tab หลายๆอันได้
  • Visual Mode ทำให้การ คัดลอก ลบ แก้ไข เป็นเรื่องง่ายขึ้นมาก เลือกเป็นแบบ จุดเริ่มต้น-สิ้นสุด เป็นบรรทัด หรือเป็นคอลัมน์ได้ (อันหลังนี่เหมาะมากสำหรับไฟล์ข้อความที่ลักษณะเหมือนตาราง)

ตอนนี้ VIM เลยกลายเป็น text editor ที่ผมมักจะใช้แทน notepad ไปแล้วครับ :) ปัญหาจะเกิดอีกทีตอนใช้ภาษาไทย ซึ่งผมคิดว่าอย่าใช้ไฟล์ text ภาษาไทยกับ VIM เลยดีกว่า คนที่น่าจะมีปัญหานี้ที่สุดคงเป็นพวกเขียนเว็บ ..

หลังจากอ่านบทความจำพวกแนะนำ vi หรือ vi สำหรับมือใหม่ มานับไม่ถ้วน ผมพบว่าคำสั่งพื้นฐานเท่าที่จะสามารถทำให้เราใช้ VIM แทน Notepad ได้ มีอยู่ไม่กี่ตัว ดังต่อไปนี้

ออกจากโปรแกรม

พิมพ์ :q! ครับ

: เป็นการบอกว่าจะมี command อื่นๆตามมา ส่วน q แปลว่าออก และ ! แปลว่าออกแบบบังคับ (ถ้าเราแก้ไขไฟล์มันจะไม่ยอมให้ออกธรรมดา)

หรืออาจจะใช้ :wq เป็นการ save แล้วออก

ถ้า save เฉยๆก็ :w myfilename

ไป Command Mode

กด Ctrl + [ หรือ Esc

เราควรอยู่ใน Command Mode ตลอดเวลาที่ทำงานครับ ใช้ Insert Mode เฉพาะเวลาจะพิมพ์เท่านั้น :)

เคลื่อน cursor ไปมา

ใช้ปุ่ม h j k l แทน ซ้าย ล่าง บน ขวา

ถ้าพบว่าจำยาก ลองมองตัว j ว่ามันเหมือนลูกศรชี้ลงล่าง! แล้วจะจำได้ครับ (ได้มาจาก video youtube ซักอัน)

การเคลื่อนในระดับคำ

  • w ไปคำต่อไป
  • b คำก่อนหน้า

ระดับบรรทัด คล้ายๆกับ regex

  • ^ ต้นบรรทัด
  • $ ท้ายบรรทัด

ระดับ document

  • gg ต้น document
  • G ท้าย document

ไป Insert Mode

เข้าได้หลายแบบ แบบแรกควรรู้คือ a กับ i

  • a ต่อหลัง cursor
  • i วางหน้า cursor

และแบบที่สอง ที่หลังจากใช้สองอันแรกจนเจอปัญหาบางอย่างแล้วจะพบว่า Useful มาก คือ

  • A หลังสุดของบรรทัด
  • I หน้าสุด

และแบบสุดท้าย เป็นการแทรกบรรทัดว่างๆเข้าไป

  • o แทรกบรรทัดใหม่ ใต้บรรทัดปัจจุบัน
  • O แทรกบรรทัดใหม่ เหนือบรรทัดปัจจุบัน (So useful!)

ยกเลิก – Undo

กด u

อยาก Redo กด Ctrl+r

Autocomplete

  • กด Ctrl + P เป็นการเติมจากคำก่อนหน้า
  • กด Ctrl-x-f เป็นการเติมชื่อหรือพาธไปยังไฟล์ กด Ctrl-f ต่อจะวนรอบชื่อไฟล์ไปเรื่อยๆ
  • กด Ctrl-x-o เป็น omni-completion อาจจะต้องลง plug-in เพิ่มสำหรับไฟล์บางแบบ (เช่น C++)

เพิ่มตัวบอกบรรทัด

:set ruler

Visual Mode

มีสามแบบ

  • แบบเริ่มต้น - สิ้นสุด กด v
  • แบบบรรทัด กด V
  • แบบคอลัมน์ (Visual Block Mode) กด Ctrl + V

หลังจากกดแล้วจะใช้ cursor เลื่อนซ้ายขวาเพื่อ select ข้อความได้ ซึ่งหลังจาก select แล้วอาจจะทำอะไรได้หลายอย่าง เช่น

  • ลบ กด d
  • คัดลอก กด y (yank) เวลาจะเอาไปวางก็กด p หรือ P
  • แทนที่ กด c แล้วพิมพ์คำตามเข้าไป แล้วกด enter (จะเห็นประโยชน์ตอนใช้ในแบบคอลัมน์)
  • เพิ่ม tab ด้านหน้า (indent) กด >

ค้นหา

อันนี้ใช้บ่อยสุดๆ กด / แล้วพิมพ์ regular expression ของคำที่ต้องการค้น เช่น /search_key_word

นอกจากนี้ยังมีวิธีค้นหาแบบใช้ * คือเลื่อน cursor ไปเหนือคำที่ต้องการค้นหาแล้วกด * จะทำให้ VIM ทำ highlight ให้กับคำเดียวกันทุกคำในเอกสารนั้น เหมาะเวลาที่จะใช้เปลี่ยนชื่อตัวแปร หรือไล่โค้ด อะไรทำนองนั้น

แทนที่ – Replace

ใช้คำสั่ง :%s/before/after/gc

  • ตัว c แปลว่า confirm คือให้ถามก่อนแทนที่
  • ถ้าไม่มีตัว g มันจะแทนที่แค่บรรทัดละตัว
  • before และ after เป็น regular expression ของตัวที่จะให้แทนก่อนและหลัง
  • s เป็น substitute command
  • % เป็นการบอกว่าแทนทั้งไฟล์ (จริงๆแล้วบอกเป็นเลขบรรทัดได้ แต่จะไม่ cover แล้วกัน)

จัดย่อหน้าให้สวยงาม

หลังจาก save ไฟล์ไปแล้ว VIM จะฉลาดพอที่จะทำ syntax highlight สวยๆให้ดู รวมถึงจัดย่อหน้าให้ไฟล์ให้ถูกต้องตามประเภทไฟล์ (เช่นไฟล์ .c .cpp)

กด gg=G

Tabs

จำเป็นเหมือนกันเวลาต้องเปิดสอง (หรือมากกว่า)ไฟล์คู่กัน จริงๆแล้ว VIM มันมี buffer ให้ใช้หลายๆอันด้วย แต่ผมว่า concept ของ Tab มันเข้าใจง่ายกว่านะ

  • :tabnew path/to/filename เปิดไฟล์ หรือสร้างไฟล์ใหม่
  • :tabc ปิด tab ปัจจุบัน
  • gt และ gT ไปแทบต่อไป และก่อนหน้า

แก้ไขจาก command mode

การแก้ไขหลายอย่างทำจาก command mode ได้ ในที่นี้ผมรวม command แบบที่ต้องใช้ประกอบกับ motion ไว้ด้วย แต่ขอละไว้ เนื่องจากผมเองก็ไม่คล่อง –*- เอาเฉพาะอันที่ใช้กันบ่อยๆแล้วกัน

  • r แก้หนึ่งตัวอักษร
  • x ลบหนึ่งตัวอักษร
  • dw ลบคำปัจจุบัน
  • dd ลบทั้งบรรทัด
  • dfg ลบจนถึงตัว g หรือ df” ลบจนถึงเครื่องหมายคำพูด
  • d$ (ลองเดาดู)
  • ggdG (ลองเดาดู)

ทำซ้ำคำสั่งสุดท้าย

กด . 

ผมไม่ค่อยได้ใช้แฮะ

note: ตัวที่ผมใส่สีน้ำเงินไว้ แปลว่าสำคัญอย่างยิ่งนะครับ :)

สิ่งนึงที่ผมเห็นว่า tutorial vi มักจะสอนคือการใช้ตัวเลขนำหน้าคำสั่งเพื่อบ่งว่าจะให้ทำคำสั่งนั้นกี่ครั้ง ซึ่งผมว่า มันแทบไม่ได้ใช้เลยว่ะ … โดยเฉพาะใน VIM ที่มี visual mode

การมี editor พื้นฐานสำหรับแก้ไฟล์ หรือ อ่านไฟล์ ง่ายๆบน unix ซักตัว เป็นอะไรที่ผมแนะนำอย่างยิ่งครับ และผมแนะนำ VIM เหนือ emacs (ไม่รู้ editor มันจะมี game tower of hanoi ไปทำไม ใช้ก็ยาก :[ )

ไปดาวน์โหลด VIM

Tags:

Jun 10 2009

มาจดโน้ตกันเถอะ

Category: Toolsm3rLinEz @ 21:58

เวลาเราเข้าไปเรียนรู้ปัญหาในโดเมนใหม่ๆหรือทำโปรเจคอะไรซักอย่าง มันย่อมมีการ จด จด จด และจด ข้อมูลสำคัญที่เราอาจจะต้องใช้อีกบ่อยๆในอนาคต หรือไม่ก็เป็นข้อมูลที่มักซ่อนตัวอยู่ในเอกสารที่เข้าถึงยากๆ จดมาไว้รวมกันที่เดียวก็จะทำให้ค้นหาง่ายกว่า ยกตัวอย่างเช่น ถ้าเราไปเรียนภาษาโปรแกรมมิงใหม่ๆเราอาจต้องการเขียนโค้ดโปรแกรมสั้นๆ (ที่ยาวกว่า Hello World) ซักโปรแกรมนึงไว้เพื่อเป็นตัวแทน Syntax ของภาษานั้นๆเอามาใส่ไว้ในโน้ตของเรา เป็นต้น นอกจากนี้ยังเป็นการบันทึกไอเดียที่เกิดขึ้น “วูบ” หนึ่ง ไว้ไม่ให้หายไปอีกด้วย

มาดูกันดีกว่า ว่าชาวบ้านชาวเมืองเค้าใช้เครื่องมืออะไรในการจด “โน้ต” กันบ้าง :)

กระดาษ / สมุด

ไม่ต้องใช้อะไรมากมาย กระดาษ ดินสอ นี่แหละ

GF 01

ข้อดี

  • จดได้ค่อนข้างจะ Free form มากครับ จะวาดรูป ทำเส้นชี้ อะไรยังไงก็ได้
  • ให้ความรู้สึกดีสำหรับคนที่ต้องการอะไรสัมผัสได้
  • ใช้ง่าย

ข้อเสีย

  • ค้นหา / คัดลอก / แก้ไข ข้อมูลยาก ยังไม่นับเรื่องคนที่ลายมือห่วยอ่านลายมือตัวเองไม่รู้เรื่องอีกนะ (ผมคนนึง  - -‘)
  • มีอุปกรณ์เพิ่มอีกหนึ่งชิ้นเวลาไปไหนมาไหน

บลอก

จะจดไว้คนเดียวทำไม แบ่งให้คนอื่นอ่านด้วยดีกว่า :D

m3rlinez_blogspot

ข้อดี

  • เผื่อแผ่ความรู้สู่โลก!
  • เพิ่ม visibility ของตนเองในสังคม internet
  • ได้รับ feedback จากผู้อ่าน สำหรับวิธีที่ดีกว่า หรือข้อมูลเพิ่มเติม
  • เข้าจากที่ไหนก็ได้ที่ต่อ Internet :P
  • เขียนดีๆ คนเข้าเยอะ ยังทำเงินค่าขนมได้จากการแปะ Ads อีกตะหาก
  • ค้นหาง่าย
  • ฝึกฝนภาษา (ถ้าเขียนเป็นภาษาอังกฤษนะครับ)

ข้อเสีย

  • จะเขียนซักอย่างต้องใช้เวลากลั่นกรองนาน เช่น เป็นเรื่อง confidential รึเปล่า หรือเขียนไปแล้วคนจะอ่านรู้เรื่องรึเปล่า
  • เสียเวลาจัด format เช่นต้องทำตัวหนา ทำหัวข้อ ใส่รูป
  • เขียนไปแล้วไม่มีคนคอมเม็นต์จะเสียกำลังใจเล็กน้อย

วิกิส่วนตัว

เพิ่งได้ลองวิธีนี้มาเป็นเวลาสองเดือนกับ Tiddly Wiki ครับ ข้อดี + ข้อเสีย ส่วนใหญ่ก็เหมือนกับบลอก ผมตั้งไว้เป็นหน้าแรกใน Firefox ที่ทำงาน โปรแกรมมันใช้ง่ายมากเลยครับเพราะเป็นไฟล์ HTML ธรรมดาไฟล์เดียว (งงล่ะสิ ว่าแล้วมันมี permission แก้ไขตัวเองได้ยังไง ฮาาา)

tiddlywiki

ข้อดี

  • ทำ cross reference ได้ เวลามี term บางอย่างที่อาจจะไม่เคลียร์ เช่น พวกตัวย่อ ก็จะสามารถทำลิงค์ไปหาหน้าที่อธิบายตัวย่อนั้นได้
  • ทำงานเร็วมากเพราะรันบนเครื่อง ไม่ต้องใช้ internet
  • เขียนอะไรสั้นๆ อ่านรู้เรื่องคนเดียวได้
  • ค้นหาง่าย

ข้อเสีย

  • วุ่นวายกับการ sync ถ้าต้องใช้บน PC มากกว่าหนึ่งเครื่องขึ้นไป ( เอ่อ … Mac ก็ใช้ได้นะ ..)
  • มี syntax สำหรับการเขียนวิกิโดยเฉพาะ บางทีก็งงๆว่าจะทำตัวหนา หรือใส่รูป ต้องทำยังไง ..

นอกจากเครื่องมือต่างๆที่กล่าวมาแล้ว ยังมี Tool สำหรับจดโน้ตโดยเฉพาะเช่น Microsoft OneNote, Google Notebook เป็นต้น

อ่อ โพสต์นี้เป็นการกลั่นกรองข้อมูลจากกระทู้ดีๆใน StackOverflow.com นะครับ :)

Tags: , ,

Mar 4 2009

ทดลองใช้ ANTS Profiler

Category: .NET | Toolsm3rLinEz @ 21:24

เหมือนที่ชื่อบอกครับว่ามันคงเป็นผลิตภัณฑ์ในตระกูล Profiler นั่นแหละ

Profiler เป็นโปรแกรมที่ไว้วัดประสิทธิภาพในการทำงานของโปรแกรม โดยอาจจะวัดในแง่เวลาการทำงาน หรือหน่วยความจำที่ใช้ โดยวัดกันได้ถึงระดับ Class, Method เลยทีเดียว ตัวที่เอามาลองวันนี้เป็นของ Redgate ทดลองใช้แบบ Evaluation ได้ 14 วันครับ

โปรเจคที่เอามาลองเป็นโปรเจค C# ในวิชา Game Programming ซึ่งเป็นเกม 3D ที่ใช้ Graphics Engine ตัวหนึ่งชื่อ OGRE3D (หรือสั้นๆว่า OGRE : Object-Oriented Graphics Rendering Engine) ตัวเดียวกับที่ใช้ทำ Senior Project

ตอนแรกก็สงสัยเหมือนกันว่าแล้วเราใช้ Library เสริมในลักษณะนี้ แล้วตอนทำ Profile โปรแกรมมันจะไม่อืดน่าดูเหรอ (ยิ่งเป็น Application ประเภทเกมด้วย) ปรากฎว่าตอนลองทำ Profile ดูแทบไม่เห็นความแตกต่างเลยครับ ตัวโปรแกรมก็ใช้ง่ายมาก มีการทำ Profile ได้หลายแบบ ทำไปสองแบบคือ Profile Performance และ Profile Memory เอามาให้ดูเฉพาะ Profile Performance

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

สรุปว่าก็เป็น Tool ที่มีประโยชน์ครับ ไว้หาคอขวดของโปรแกรม คือส่วนที่ทำงานช้าที่สุด (ในเคมีเรียกว่าขั้นตอนกำหนดปฎิกริยาสินะ) และ Profile Memory ก็เอามาไว้ช่วยหา Memory Leak ได้ (ยังใช้ไม่เป็น - -‘a)

Tags:

Jan 5 2009

CUAuth: ลอกอินเน็ตเวิร์กจุฬาอัตโนมัติ

Category: .NET | Toolsm3rLinEz @ 20:36

อันนี้เป็นผลงานร่วมระหว่างผมกับน้องบุ๊ค (@hybridknight) นะครับ จริงๆมีความคิดเรื่องแนวๆนี้ผ่านเข้ามาในหัวเรื่อยๆบ้างตั้งแต่ตอนเรียนวิชาเกมแล้วขี้เกียดลอกอิน เพราะว่าบางทีก็พิมพ์รหัสนิสิตผิด พิมพ์เกินบ้าง ขาดบ้าง บางทีก็พิมพ์ password ตัวเองลงไปผิดช่อง คนอื่นมาเห็นก็แย่เลย บางทีพิมพ์ครบหมดก็ลืมกดยอมรับข้อตกลงอีก ..'' ก็เลยเป็นเรื่องที่ ... annoying พอสมควรครับ

ไอเดียเริ่มต้นคงอธิบายได้ด้วย Conversation ชุดนี้

ปัญหาอย่างเดียวของการลอกอินอัตโนมัติก็คือเจ้า "Captcha" นี่เอง  แต่เนื่องจาก captcha ที่เราเจอในเคสนี้ยังไม่หนักหนาสาหัสถึงขั้นจะแกะไม่ได้ครับ มีลักษณะคร่าวๆดังนี้

  • ประกอบด้วยสีมากมาย
  • มีเส้นพาดไปพาดมามากมายในฉากหลัง
  • แต่ละตัวอักษรหมุนเอียงไปในทิศทวนเข็มนาฬิกา (เท่านั้น) ด้วยองศาไม่เท่ากัน

ก็เลยได้ไอเดียที่ว่าจะอ่านตัวอักษรในภาพได้ต้องทำดังต่อไปนี้

แยกเฉพาะตัวอักษรออกมาก่อน ทำโดยการแยกส่วนของภาพที่มีสีของตัวอักษรเท่านั้นออกมา ทำได้โดยการวิเคราะห์ Histogram หากสังเกตดูดีๆก็จะพบว่า สีของตัวอักษรนั้นจะเป็นสีที่ครอบครองพื้นที่ในรูปมากเป็นอันดับสองเสมอ (อันดับหนึ่งคือสี Background) ก็สามารถแยกออกมาได้โดยง่าย

ทำ OCR บนตัวอักษรที่แยกออกมา เลิกคิดเรื่องเขียนเองไปได้เลย หลังจากควานหา library ดูซักพักก็พบ  tesseract-ocr ที่ดูแลอยู่โดยพี่ Google แต่เนื่องจากตัว library มันเป็น C/C++ ดังนั้นถ้าจะเอามาใช้กับ .NET ก็จะวุ่นวายพอสมควร จะให้ไปเขียน C/C++ ก็คงมากไปสำหรับโปรเจคเขียนเล่นเอามัน ควานไปเรื่อยๆเจอคนใจดีทำ wrapper ไว้ให้ คือ Tessnet .NET Tesseract wrapper ทำให้ OCR ง่ายไปเลย (โค้ดตัวอย่างจากเว็บ)

Bitmap image = new Bitmap("eurotext.tif");


tessnet2.Tesseract ocr = new tessnet2.Tesseract();


ocr.SetVariable("tessedit_char_whitelist", "0123456789"); // If digit only


ocr.Init("fra", false); // To use correct tessdata


List<tessnet2.Word> result = ocr.DoOCR(image, Rectangle.Empty);


foreach (tessnet2.Word word in result)


    Console.WriteLine("{0} : {1}", word.Confidence, word.Text);

หลังจากได้ทุกอย่างมาครบ ก็เริ่มทำโปรเจค มีการใช้คลาสพวก HttpWebRequest พวกนี้นิดหน่อยตามธรรมชาติของโปรแกรมลักษณะนี้

ผมได้โปรแกรมตั้งต้นหน้าตาเป็นแบบนี้

และหลังผ่านการปรับปรุงและเพิ่ม Feature เช่นแก้ส่วนของ Keep-Alive, จัดโปรแกรมลง Tray, และอื่นๆ โดยคุณน้องบุ๊ค @hybridknight ก็ได้อะไรประมาณนี้ออกมา http://twitpic.com/xmfe

โปรเจคนี้ทำเล่นเอามัน และ communicate ผ่าน Twitter ตลอด (จนเพื่อนบางคนอาจจะรำคาญ - -''a) ไม่มีจุดประสงค์ใดแอบแฝง

ตัวโปรแกรมและซอร์สโค้ด จะอัญเชิญเวอร์ชันล่าสุดจากน้องมาโปะให้เร็วๆนี้นะครับ และโปรแกรมนี้เพื่อการศึกษาเท่านั้นนะ :P

Tags: , , , , , , ,

Jul 6 2008

ลอง MySQL Workbench

Category: Toolsm3rLinEz @ 03:02

วันก่อนไปฟังงานสัมนาประจำปีของ Software Park ที่ศูนย์ประชุมแห่งชาติมา เข้าฟังหัวข้อที่เป็น "MySQL - Yes, We can scale" พูดโดย ดร.ธนชาติ มา (ผมเคยเจอ ดร.ธนชาติอีกหนตอนท่านเป็นกรรมการในโครงการ Samart Innovation Awards)

เนื่องจากว่าตอนนี้ Sun ซื้อ MySQL มาเรียบร้อยแล้ว ก็เลยต้องโปรโมตกันหน่อย เรื่องของเรื่องคือ ดร.ธนชาติ พูดจนผมกลับบ้านมาอยากลองใช้เลยครับ บางคนอาจจะถามว่าอยู่มาได้ยังไงไม่เคยใช้ ผมก็เคยมีงานที่ต้องยุ่งๆกับ MySQL เยอะพอควร แต่ไม่เคยต้องทำงานออกแบบทั้งหมดบน MySQL เลย (เคยแต่ใช้ MS Access ต่อมาก็ SQL Server แล้วก็ Oracle) เคยแต่งานประเภทปรับปรุง แบ็คอัพ ใช้ phpMyAdmin เป็นบ้าง

ปัญหาอย่างหนึ่งของเจ้า phpMyAdmin คือ มันไม่มี GUI สวยๆประเภทลากแปะๆให้ใช้ ผมเลยต้องหาทางเลือกอื่น เคยใช้ DBDesigner มาก็ไม่ค่อยประทับใจเท่าไหร่ จนไปเจอ MySQL Workbench เข้า อินเทอร์เฟซบาดใจมากครับ

ปัญหาอย่างเดียวคือ เวอร์ชันที่มันฟรี (OpenSource) มันไม่สนับสนุนการ Sync กับตัว MySQL Server ที่ทำได้ก็คือต้อง export เป็นไฟล์ .sql แล้วไปเรียกคำสั่ง mysql ผ่าน cli เอาเอง (หรือไม่ก็ใช้ import ใน phpMyAdmin) 

ลองไปเล่นกันดูครับ ดาวน์โหลดที่ http://dev.mysql.com/workbench

Tags: ,

Aug 22 2005

MinGW Developer Studio !

Category: Toolsm3rLinEz @ 00:00

วันนี้คะแนนฟิสิกส์ออกแล้วว่ะ = =''
จะว่าไปก็ไม่ค่อยดีเท่าไหร่ ได้ 32.7 จากเต็ม 50% วุดได้ 34.8 ฟิตว่ะ ~
หลุนนี่พุ่งเ้ข้าไป 44%

คะแนนหมอก็ออกแล้วเหมือนกัน แต่ของหมอเรียน Physics for Med. กุไม่รุเหมือนกันนะว่้ามันต่างจากฟิสิกส์หนึ่งที่พวกเราเรียนกันยังไง แต่มีคนบอกมาว่า หมอแม่งไม่มีใครได้เิกิน 40% เลย ยกเว้นไอชรัตคนเดียว ที่ได้ 50% เต็มๆ !!! (เห็นมันบ้าๆอย่างนั้น แต่เท่าที่เรียนตอนม.ห้าด้วยกัน มันก็ได้คะแนนเต็ม หรือไม่ก็ขาดไปคะแนนสองคะแนนตลอด)

MinGW Developer Studio !
วันนี้มีเรื่องใหญ่เรื่องนึงจะเขียน คือเมื่อวานไปอ่านบอร์ด Developer ของ Dev-C++ มา เพราะเราก็รออยู่ว่าเมื่อไหร่มันจะออกเวอร์ชัน 4.9.9.3 ซักที แล้วเจอคนในบอร์ดพูดถึงโปรแกรม MinGW Developer Studio เราก็เลยตามเข้าไปโหลดที่เว็บ http://www.parinyasoft.com มา ... แวบแรกที่เห็นชื่อเว็บก็ .. เอ๋ย์ ... สะกิดๆ คนไทยรึเปล่าวะ ...

หลังโหลดโปรแกรมขนาด 26 MBs มาเสร็จเรียบร้อยแล้ว เราก็เริ่มทดลองใช้งาน เออ โปรแกรมนี้แจกให้ใช้ฟรีนะ แต่ไม่ใช่ open source แล้วเราก็เปิดหน้า About .. ดู ปรากฎว่าตรงชื่อคนเขียนโปรแกรมเป็น

Parinya Thipchart

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

สุดท้ายเลย เมวล์ไปถาม และัเมื่อกี้นี้เอง ที่เพิ่งได้รับคำตอบ ขออนุญาตเอาเมวส่วนตัวมาลงไว้ตรงนี้แล้วกัน

Parinya Thipchart 
to me
 More options   11:02 am (4 hours ago)
On 8/21/05, Nattawut Kulnirandorn <m3rlinez@gmail.com> wrote:
> Hi,

Hi,

> I downloaded your MinGW Developer Studio and it works really fine.
> After I had read your full name in about box. I realize that your name
> is similar to be a Thai word. So I want to know if you are Thai or
> have something relate to Thailand. I can't believe that there is such
> a great Thai developer!

Thank you very much!
Unfortunately, I don't have enough time lately.
I don't even have a chance to look at it, add new features or test it.
I hope that I would have enough time in the near future. (Well, I keep
thinking like this but it hasn't happened yet :)

>If you are Thai please let me know.

Yes, I'm 100% Thai krub.
Great to hear that there are some thai people are using my program! Thanks!

>Sorry to ask personal question.

No problem!

Parinya



ออ... ก่อนอ่านต่อคงต้องขออะไรอย่างนึง ว่าอย่าจับผิดแกรมมาร์ชั้นให้มากนักนะเว่ย = ='' ยิ่งเขียนไม่คล่องๆอยู่ ตอนแรกเราก็เดาไปเลยน่ะ ว่าเค้าเป็นลูกครึ่ง หรือเป็นเด็กไทยที่เกิดที่โน่น อะไรแนวนี้ พยายามเขียนจดหมายให้ดูสุภาพเต็มที่ (แต่ก็ได้แค่นี้อนะ o O ~)

เราคิดว่า้ถ้าจะเรียนสายคอมแล้วทำงานในบ้านเรา (ประเทศไทย) งานก็คงหนีไม่พ้นเขียนโปรแกรมจัดการ Database, เขียนเว็บขายของ, ส่งเมว spam, ดิกชันนารี, CAI แผ่นละ 180 อะไรพวกนี้หรอก ก็ดีใจที่ยังมี Developer ชั้นสูงที่เป้นคนไทย ที่กล้าเขียนอะไรให้มันแหวกแนวอยู่บ้าง แล้วไอ่โปรแกรมที่บอกมานี่ มันก็ไม่ได้เขียนง่ายๆเลย แถมยังมีเวอร์ชันที่รันบนลินุกซ์อีกตะหาก เราเองก็อยากทำอะไรได้ขนาดนี้บ้าง

พูดเรื่องคนไทยในต่างแดนเ่่ก่งๆแล้ว ทำให้นึกถึงเ้จ้าของบลอกอีกที่นึง คือที่ http://vuthi.blogspot.com/  บลอกที่นี่ก็มีแ่ต่เรื่องคอมจริงๆ เราเข้าไปเจอตอนเสิร์ชเกี่ยวกับการตัดคำภาษาไทยใน firefox (เพราะคำไทยมันเขียนติดกันไปเป็นพืดๆ ไม่ได้แยกด้วยช่องว่างแบบภาษาอังกฤษ การตัดคำเพื่อขึ้นบรรทัดใหม่จีงเป็นปัญหา) พี่คนนี้เ้ค้าก็ทำ firefox ตัดคำไทยไว้เวอร์ชันนึงเหมือนกัน ถ้าสนใจก็ลองเข้าไปดู บลอกนี้เราก็เข้าไปบ่อยๆ อ่านแ้ล้วรู้สึกได้รู้อะไรเพิ่มขึ้นเยอะ รุสึกพี่เค้าจะเรียนหรือทำงานอยู่ในญี่ปุ่นนี่แหละ

ว่าไปแล้วนึกย้อนไปเราน่าจะลองสอบทุนอะไรพวกนี้เล่นๆไว้บ้าง พูดตามตรงว่าตอนนี้อยากเป็นอาจารย์มหาลัยว่ะ จริงๆก็ไม่ได้ชอบสอนหนังสือมากหรอก เพราะสอนแล้วคนฟังไม่รู้เรื่อง (o O ~ ) แต่ที่อยากเป็นเพราะจะได้ทำในเรื่องที่ตัวเองสนใจได้อย่างเต็มที โดยไม่ต้องแคร์อะไรตะหาก แต่เรื่องทุนสำหรับเราก็คงไกลตัวเกินไป


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

ปิดท้ายด้วย ... รูปที่ไม่เกี่ยวข้องกับเรื่องด้านบน เช่นเคย .. (นโยบายกันไดอารี่จืด)


เจอรูปทีมเว็บเก่าอันที่ยังไม่แก้สีแล้ว!
แถวซ้าย: จานวิชัย พี่ซี พี่วง มีมี่
แถวขวา: แก๊น(หน้าเถื่อนว่ะ) ปริย กิ๊พ

Tags: