Skip to main content

Graphviz quick start with example

Graphviz là gì?
What is Graphviz?
Là một phần mềm giúp thể hiện các diagram(biểu đồ các loại) bằng cách viết ra một file "source code"
Nó là open source và free nhé.
It's open source graph drawing tool by typing some text.

Tại sao nên dùng Graphviz?
Why should use Graphviz?
Sau một vài năm tháng sinh nghề tử nghiệp với mạch điện tử, với các loại code kèo, không may mắn mình bị mắc hội chứng ống cổ tay . Bệnh này làm mình trở lên khó chịu với từng cú click chuột. Chất lượng cuộc sống xuống dốc không phanh đến nỗi nhiều lúc đã định nghỉ việc. Sau khi đi thăm khám và thử vài liệu pháp treatment không hiệu quả từ những lang y như từ mẫu, mình nhận ra là chẳng ai cứu được mình ngoài mình.
Anytime you heard about
Mình bắt đầu lên kế hoạch giảm tối đa các thao tác với chuột máy tính. Và Graphviz là một phương thuốc trong bộ giải pháp đó. Hi vọng guideline dưới có thể là một giải pháp hỗ trợ những người bị bệnh giống như mình.

Và thế nên, đừng hỏi mình tại sao không dùng Visio, Astah thậm chí là excel, và một ti tỉ các tool khác trên đời để vẽ diagram.

Dùng thử tính năng chính
Bài toán đặt ra:
Input: source code
Output: graph ?

Bài giải:
Hãy copy source code các example ở đây
http://graphs.grevian.org/example

Sau đó paste vào text box
http://graphs.grevian.org/graph

Chọn cách layout tương ứng (dot, neato ...etc)
Sau đó generate ra graph tương ứng.

Nếu bạn bị lỗi
</pre>
 Error: Failed to generate your graph (Error [400]), perhaps a syntax error?
<pre>
Hãy thử chỉnh lại các tab trong source code (thường là chỗ graph hoặc dấu "}")

Nếu bạn cảm thấy hứng thú thì tiếp tục đọc.
Không thì hay close this window và đi tìm một thứ thú vị hơn để làm cho đỡ lãng phí thời gian.

Cài đặt:
http://www.graphviz.org/Download.php
 
Kiểm tra cài đặt
Mở cửa sổ MSDOS gõ "dot --help"
Trường hợp 1: Command này được nhận ra thì OK, done.
Trường hợp 2:
'dot' is not recognized as an internal or external command,
operable program or batch file.

  
Bạn phải chỉnh lại biến môi trường
Start/Computer/Property/Advance System Setting/Environment Variables/PATH
Ấn Edit và paste dòng dưới vào cuối của text box "variable value"
<pre>
;C:\Program Files (x86)\Graphviz2.38\bin
</pre>

Check lại bằng lệnh "dot --help". Nếu không được thì thử restart lại PC hoặc sửa luôn cái PATH của phần System Variables. Nếu không được nữa thì mình chịu, google giúp đi

Chạy thử chương trình đầu tiên.
Copy source code nào đó bạn thích. (cái nào ngắn thôi nhé, ko fix bug nản lắm :D)
Ví dụ: http://graphs.grevian.org/graph/6537066003300352

Save nội dung vào file example1.gv (ví dụ đặt file này vào thư mục C:\example)
Mở cửa số MSDOS, nhảy vào thư mục tương ứng bằng lệnh cd
Gõ lệnh sau:
dot -Tjpg example1.gv -o example1.jpg

Trong đó
dot: lệnh của grapviz (bạn có thể dùng neato, twopi ..etc, nhớ là phải tương ứng với nội dung của file source gv
-Tjpg: tham số cho phép xuất ra output dạng jpg
example1.gv: tên input file (source code)
-o : tham số output file
example1.jpg: output file

Cuối cùng, kiểm tra thành quả jpg và tiếp tục vọc nhé.
Chúc thành công.

More Example
digraph G
{
    // Set shape
    node [shape=box]
   
    // Simple box
    node0 [label="TextBox 0 content"]

    // Box is filled
    node1 [style=filled, label="TextBox 1 content" ]

    // Box is filled by red color
    node2 [style=filled, fillcolor=red, label="TextBox 2 content"]

    // Set connection between each nodes
    node0 -> node1 -> node2
}

Reference :
Dot language
https://en.wikipedia.org/wiki/DOT_(graph_description_language)

Comments

Popular posts from this blog

[Git] Handle trailing space when patching with git

After complete coding one module in development branch. Next phase is merging. Obviously, you can merge source code automatically without no errors happen. However, life is not dream. Create a patch git diff HEAD > newTariff.patch Apply patch git apply newTariff.patch then problem happens Problem git apply newTariff.patch:106: trailing whitespace. patch does not apply Route cause: Nguyên nhân: Do trong source code có những dấu space thừa (ô vuông màu đỏ hình dưới) Some whitespaces is existed in your patch. (red area in below pictures) Fix Clean white space and patch again. Cách khắc phục Xóa những dấu space này đi và thực hiện patch lại Make up after complete coding. Find and clean whitespace before create patch file. Sửa sau khi code xong Kiểm tra sau khi code xong có lỗi này không git diff HEAD --check Prevent whitespace by manually when typing source code Sửa ngay khi đang code =>Bật chức năng hiển thị các dấu whitespace, hoặc remove trailing ...

How to test frame buffer in linux

The intended goal of this article is to provide the user with enough information so they can display an image onto a screen of their choosing. How to re-build frame buffer testing application. Base knowledge http://trac.gateworks.com/wiki/OpenEmbedded/Video_Out Frame buffer test application - rebuild fb-test-app step 1: Download soure code ( git installed on your machine and account in git-hub is required) https://github.com/prpplague/fb-test-app Command in git: git init git clone https://github.com/prpplague/fb-test-app.git step 2: Change makefile vi Makefile //open Makefile by vim editor :set nu //show line number replace from line 6 to line 12 by folow code: CC=arm-linux-gnueabi-gcc CFLAGS=-02 -Wall Save change command :wq step 3: Rebuid Type “make” command step 4: Copy execute file to target system by filezilla or something like that step 5: Remote target by root account, change mode of execute file (what copied from host) ...

[Vi] Công nghệ phát triển ngược đời - How is AI harming my world

Tiếng cười khanh khách của mấy cậu sinh viên quốc tế người Bắc Ấn sau bài kiểm tra cuối khóa (a final exam) làm gã thấy buồn một góc tâm hồn. Sự trống rỗng ngay lập tức xâm chiếm lấy tâm trí gã sau khi nộp bài môn thi cuối cùng của kỳ học. Gã hiểu gã quá mà, gã đang cố gắng giải thích cho nỗi nhục của chính bản thân ở bên trong. Đầu gã thoáng nghĩ về cái lần thi cuối kỳ một môn học ở bậc thạc sỹ nơi quê nhà hơn mười năm về trước, cái ánh mắt khinh bỉ đến ám ảnh của một anh dọn vệ sinh dành cho những học viên cao học đang quay cóp trong giờ thi của một trường đại học hàng đầu quốc gia như vết dao khứa vào lòng tự trọng của gã. Vết thương vẫn nhói đau lại khi những mùa thi đến. Một lão già sinh viên quốc tế ranh ma. Gã đang học lại cái thứ mà gã đã học từ hai mươi năm về trước với một thứ ngôn ngữ không mới và cái tâm bằng sắt nung. Kinh nghiệm làm việc chuyên môn lâu năm cộng với việc vừa được trang bị thứ vũ khí khoa học tối tân AI (Trí truệ nhân tạo) khiến lão trở thành sát thủ trong ...