Coding Defines Anything งานนี้เป็นครั้งที่ 4 แล้ว โดยจัดที่หอประชุมคณะวิศวกรรมศาสตร์ จุฬาลงกรณ์มหาวิทยาลัย ครับ สำหรับผมที่มา เพราะ หัวข้อ Keynote ครับ พอดีมีปัญหากับเรื่อง Design อยู่ โดยในงานหัวข้อที่ผมได้ฟัง มีดังนี้ครับ (ถ้าเรื่องไหนมันใหญ่ไป ผมจะแยกไปอีก Blog นะครับ)
ช่วงเช้า
- [BLOG] Coding Defines Reality – Emergent Design with Code (Speaker: Varokas Panusuwan)
- Flash talk
- ทำ Microservices แบบขำๆ กับ Docker Swarm (Speaker: Kan Ouivirach)
- [BLOG] Token based authentication ทำไปทำไม (Speaker: Yothin Muangsommuk)
- Increase Productivity with NodeJs (Speaker: Apaichon Punopas)
- Girls Who Dev (Speaker: Nattanicha Phatharamalai)
- Git as NoSQL Database (Speaker: Somkiat.co.cc) | Slide
- Knowledge Representation and Reasoning (Speaker: Teeradaj Racharak) | Slide
ช่วงบ่าย
- Coding Defines Innovation "The power of Hackathon" (Speaker: Theeraphol Wattanavekin)
- Hackathon -> มาจาก Hack + Marathon
- Hackathon คืออะไร
- Event สั้นๆ เพื่อเป้าหมายที่กำหนดไว้
- อะไรก็ได้ ที่ไหนก็ได้
- Team ทำที่ไหนก็ได้
- Fail faster, Success Sooner
- Hackathon เป็นอะไรก็ได้ ไม่จำเป็นต้อง Coding เช่น งานของ Google Translate เอานักแปลมาช่วยกันแปล สร้างข้อมูลที่ถูกต้อง
- Loss or Win.. It doesn't matter เพราะ อย่างน้อยคุณได้เรียนรู้
- คำแนะนำสำหรับคนทีอยากไป
- ตั้งเป้าหมาย
- เตรียมตัวบ้าง เช่น งานใช้ Golang .คุณควรรู้นิดหน่อย
- พยายาม Communicate + Make Friend
- หรือจัดเองในทีม ในองค์กร ก็ได้ ไม่จำกัดจำนวนคน แต่ในใจต้องพร้อม เวลาในการจัดไม่ควรนานเกินไป
- ทำเพื่อสังคมชุมชน Data Driven city - youpin - ส่วนตัว คือ ผมเพิ่งรู้นะว่ามีโครงการแบบนี้ เพราะ ปกติเวลาเจออะไร ผมมักจะทวิตไปให้ js100 หรือไม่ก็ส่งเข้า Fan Page ของแต่ละสำนักงานเขตครับ มาลองใช้กันดูครับ
- Slide: http://slides.com/theerapholwattanavekin/deck-1#/
- Coding Defines Code Generation "มาเขียน Java Script ยุคใหม่ ES6 (Speaker: น้อง Gatuk รุ่นน้อง มศว ครับ ชูป้ายไฟ)
- สำหรับช่วงหลังจากได้ฟังแล้ว พบว่า Blog ที่ผมเขียนเกี่ยวกับ ECMA Script 6(ES6) มันหลุดไปหลายเรื่องเหมือนกันครับ การมาฟังคนอื่นทำให้เราเจอข้อผิดพลาดของตัวเองครับ
- Coding Defines Fun "Clojure Defines Fun" (Speaker: ณัฐนาท พรประสิทธิ์สกุล แทป)
- สำหรับ Session นี้เป็นการนำเสนอ Functional Programming ครับ โดยใช้ภาษา Clojure ครับ สำหรับตอนนี้ผมอาจจะเขียน Blog งงๆนะครับ
- ภาษา Clojure มันเป็นลูกหลานมาจากภาษา Lisp
- แนวคิดในการออกแบบของมัน ไม่ปรับ Syntax แต่ไปเรียนรู้ Library
- หนังสื่อที่ Speaker แนะนำ "The joy of Clojure"
- แนวคิด REPL คือ read evel print loop
- Tools ที่ใช้ : Intelij + clojure
- ; Comma เป็น white space complier ไม่สนใจ
- Data Structure Persistence& Immutable
- vector (Array) ข้างในเป็น Tree มันมี revision ของตัวแปร ขึ้นกับว่าถือข้อมูลตรงไหน
- map key value - map ซ้อน map มีสีด้วย
- Data Stucture เป็น Function ด้วย
- nil คือ null
- Marco ทำให้ code มันสั้นลง ไม่ต้องเขียนตัวแปรซ้ำ
- ใช้ lib ของ java กับ js ได้หมด
- Ease concurrent
- Clojure ทำ front end ได้ด้วย
- Slide จาก Speaker
- Coding Defines Data-Driven Application "Data-Driven Application with GraphQL and Relay" (Speaker: อานุภาพ วิรัตนภานุ)
- GraphQL
- React & Relay & GraphQL
- Stackoverflow
- Traditional Select Join ออกมา
- 2016 Rest API
- SPA Single Page Application
- Request ผ่าน Rest มันช้า
- ปรับ API topic author join
- Mobile ?
- GraphQL - Single Endpoint
- มีอะไร ถามหา GraphQL
- Declarative Query
- any dbms or rest api อื่นๆ
- ภาษา Query เหมือน json ที่ไม่มี Value อารมณ์ประมาณ SQL
- แยกการทำงาน front กับ back ได้
- ได้ข้อมูลทุกอย่างพร้อมกัน หรือ delay ข้อมูลได้
- มีหน้า console ให้ลองด้วย graphql : true port 4000
- define schema
- define field
- define resolver
- หลังจากนี้ไป ผมฟังตามความเข้าใจ ไม่เคยเขียนตระกูล React เคยใช้แต่ Angular
- Relay
- Flux
- ปรับ schema ใหม่เหมาะกับ Relay
- Coding Defines Insights "Building Interactive Data Visualizations with d3.js" (ดร.สิโรจน์ จิรพัฒนกุล ต้า)
- Data Visualization สร้างข้อมูลให้เห็นภาพ เพื่อให้เข้าใจ
- ทำไมต้องทำ A picture worst a thousand word
- Stat มันค่ามีเหมือนกัน แต่ pattern trend ต่างกัน
- Explain Data
- Let user participate
- Highlight key information เน้น Data ให้ User follow ตาม
- Exploring Data หา Trend Pattern insight จากdata
- ต้องเลือก Visual Encoding ในการแสดงผลให้ดี เพราะข้อมูลแต่ละแบบมีการแสดงผลต่างกัน
- เลือก Filter เป็น Category เป็น key ที่เราดึงมา เพื่อสนใจตัวข้อมูล
- Sort
- Derive ข้อมูลดิบไม่พอ เราต้องเพิ่มข้อมูลใหม่ เช่น ผลรวม เพื่อมาสรุปอีก
- Navigate นำจาก Summary ไป Detail ได้
- Select เลือกข้อมูล หรือเน้นย้ำ เพื่อแสดงรายละเอียด หรือเปรียบเทียบ
- Corodinate ดูความเกี่ยวเนื่อง หา insight
- ถ้าอยากทำ
- บริการ online
- ใช้ Library D3 Data Driven Document
- ทำไม D3 ถึงทำได้หมด เบื้องหลัง คือ svg วาดรูป เองได้
- DOM Manupluation - ดูคล้ายกับ jquery เลย
- Selection in d3 เอา data ผูกกับ element
- ตัว d3 มีปรับ scale data ได้ให้เหมาะกับการแสดงผล
- d3 เป็น lib ที่รูปทุกอย่างที่เกี่ยวกับการแสดงผลง่ายขึ้น ถ้าใช้ jquery ได้ใช้หลาย lib แน่ๆ
- Slide จาก Speaker
- Software Development in 2017
- somkiat.cc - สิ่งที่น่าสนใจใน Technology Radar เดือนพฤศจิกายน 2559 จาก Thoughtworks
- สำหรับช่วงนี้คำ นึงที่น่าสำหรับผม "Connecting the dots" เรียนรู้ เพื่อเชื่อมโยงหลายๆสิ่งเข้าด้วยกัน เพื่อสร้างนวัตกรรมใหม่ๆครับ
- สำหรับหัวข้ออื่นที่ผมได้ได้ฟัง
- Coding Defines Monitoring
- Coding Defines Happiness เมื่องาน Software ไม่ใช่แต่การ Code พี่หมี BigBears.io
- เสียดายที่ไม่ได้ฟัง เท่าที่ดู Slide ตามหลังมีเกียวกับ CI, CD เยอะเลย T___T
- Slide จาก Speaker
Blog ของคนอื่นที่ไปงาน
ฺBlog ของปีก่อนๆหละ
หลังจากที่มางาน Codemania 2 - 3 ครั้ง ผมเพิ่งรู้นะว่าแต่ละครั้ง จะไม่ให้ Speaker ซ้ำหน้ากัน ให้เปลี่ยนเป็นคนใหม่ขึ้นมาพูดตลอด และ Blog สำหรับตอนนี้น่าจะไม่ละเอียดเท่ากับอันก่อนๆ มีหลายเรื่องหลุดด้วย เพราะมีงานด่วนแทรกมาระหว่างงาน ขอปิดท้ายสำหรับ Signature ของ Blog นี้ครับ อาหาร และของว่าง ครับ