KR100367134B1 - 조립식소프트웨어설계부품과그조립및분해방법 - Google Patents

조립식소프트웨어설계부품과그조립및분해방법 Download PDF

Info

Publication number
KR100367134B1
KR100367134B1 KR1019940034014A KR19940034014A KR100367134B1 KR 100367134 B1 KR100367134 B1 KR 100367134B1 KR 1019940034014 A KR1019940034014 A KR 1019940034014A KR 19940034014 A KR19940034014 A KR 19940034014A KR 100367134 B1 KR100367134 B1 KR 100367134B1
Authority
KR
South Korea
Prior art keywords
parts
design
software design
prefabricated
processing
Prior art date
Application number
KR1019940034014A
Other languages
English (en)
Other versions
KR960024909A (ko
Inventor
유홍준
Original Assignee
유홍준
Priority date (The priority date is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the date listed.)
Filing date
Publication date
Application filed by 유홍준 filed Critical 유홍준
Priority to KR1019940034014A priority Critical patent/KR100367134B1/ko
Priority to PCT/KR1995/000161 priority patent/WO1996018944A1/ja
Priority to AU41903/96A priority patent/AU4190396A/en
Publication of KR960024909A publication Critical patent/KR960024909A/ko
Application granted granted Critical
Publication of KR100367134B1 publication Critical patent/KR100367134B1/ko

Links

Classifications

    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F8/00Arrangements for software engineering
    • G06F8/20Software design
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F9/00Arrangements for program control, e.g. control units

Landscapes

  • Engineering & Computer Science (AREA)
  • Theoretical Computer Science (AREA)
  • Software Systems (AREA)
  • General Engineering & Computer Science (AREA)
  • Physics & Mathematics (AREA)
  • General Physics & Mathematics (AREA)
  • Stored Programmes (AREA)

Abstract

본 발명은, 조립식 소프트웨어 설계부품과, 조립식 소프트웨어 설계처리장치와, 본 장치를 사용하여 구현하는 소프트웨어 설계처리의 방법이며, 소프트웨어 설계처리를 규격화 및 표준화된 부품을 가지고, 그들의 조립, 추상화, 분해, 취급, 전달 및 변환 등의 처리를 통하여, 소프트웨어 개발 및 유지보수를 간단하게 행할 수가 있다.

Description

조립식 소프트웨어 설계부품과 그 조립 및 분해방법
본 발명은, 조립식 소프트웨어 설계부품과, 그것들의 조립, 추상화, 분해, 취급, 전달 및 변환 등을 처리하는 조립식 소프트웨어 설계처리 장치와, 본 장치를 사용하여 구현하는 소프트웨어 설계처리 방법에 관한 것이다.
최초의 소프트웨어 설계도였던 흐름도(flow chart)의 설계처리는, 처리, 판단, 초기화 등과 같은 기능별로 약속된 도형을, 그 속에 써넣는 문자수에 따라 크기를 임의로 정하여 비규격적으로 그리고, 비규격적으로 그려진 기능도형들을 비정형화된 화살표로 연결해가는 방법으로, 설계처리장치에 의한 자동화된 소프트웨어 설계를 구현하기 위한 프로그램의 제어구조의 인식이 어려웠다.
그 흐름도(flow chart)식 설계처리 장치와 방법에서의 문제점을 해결하기 위해 고안된 종래의 구조화도(structured diagram)들을 이용한 설계처리 장치 및 방법은, 순차(sequence), 선택(selection), 반복(iteration)과 같은 제어구조별로 약속된 도형들을 접착 또는 선으로 연결하여 구현해가는 방법으로, 설계처리 장치에 의한 소프트웨어 설계를 위한 프로그램의 제어구조 인식의 문제점을 해결할 수가 있었으며, 그로 인해 세계의 각국에서 다수의 구조화도 처리 장치 및 방법이 출현되어 소프트웨어 개발의 생산성을 향상시킬 수 있었다.
그러나, 급속한 컴퓨터의 일반 보급에 의해 범세계적인 정보화 환경이 구축되어 일반 사용자도 컴퓨터에 관해 상당히 풍부한 지식을 가질 수 있게 됨에 따라, 개발되는 소프트웨어 관한 사용자의 만족도의 수준도 점점 커져, 개발자에 대한 요구사항도 복잡다양하게 되었다.
이 때문에, 소프트웨어 개발의 비중보다 소프트웨어 유지보수의 비중이 급속하게 높아졌으나, 프로그램 제어구조 중심적 종래의 구조화도 설계처리 장치 및 방법들은 개발생산성의 향상에 중점이 놓여졌기 때문에, 한번 그려진 소프트웨어 설계도의 구조의 추상화, 구체화 및, 부분적인 변경이라던가 확장이라던가 보수 등의 유지보수성(maintainability)의 향상에의 대처가 어려웠다.
그것뿐만이 아니라, 이들 종래의 소프트웨어 설계처리 장치 및 방법들은 도형과 텍스트를 중심으로 지원되어 범세계적인 네트워크화, 멀티미디어화, 다중처리화, 병렬처리화, 가상현실화 등의 기술발전에 상응하는 설계환경을 감안한 소프트웨어 개발 및 유지보수를 위한 소프트웨어 설계예의 대처가 불가능하였다.
따라서, 상기의 종래기술의 문제점을 해결하기 위해 안출된 된 발명은, 조립식 소프트웨어 설계처리 장치에 의한 소프트웨어 설계처리 작업에 있어서 소프트웨어 설계도를 종래의 흐름도라던가 구조화도의 설계처리 방법처럼 일일이 설계도형을 연결시켜 그리는 것이 아니라, 소프트웨어 설계의 용도별로 사전에 기본부품과 블록부품과 구조부품의 3종류의 패턴부품으로 나누어 조립식 소프트웨어 설계처리 장치의 내부에 있는 별도의 기억수단인 설계부품기억부에 저장시켜둔 규격화 및 표준화된 조립식 소프트웨어 패턴부품을 마치 공장에서 산업용 로봇에 의해 하드웨어칩을 자동화된 공정으로 조립 또는 분해하는 것처럼 필요에 따라 언제라도 간단히 조립해 넣을 수 있으며, 불필요하게 된 소프트웨어 패턴부품은 기존의 설계도면에 손상을 가하지않고 언제라도 말끔히 불필요하게 된 부분만 간단히 분해하여 제거할 수 있음은 물론, 구현되어 있는 설계도면 속에서 가독성(readability)이라던가 처리기능 구분의 단순화 등의 필요에 따라 인접한 기본부품이라던가 블록부품이라던가 구조부품과 같은 패턴부품들을 묶어서 추상화시키는 등, 소프트웨어의 유지보수를 단일처리라던가 다중처리에 관계없이 용이하게 행하는 것과, 네트워크상에서의 설계처리라던가 멀티미디어를 지원하는 설계처리라던가, 가상현실 환경상에서의 설계처리라던가, 설계단계와 프로그램 코드단계와의 상호변환(forward and reverse engineering)을 지원하는 조립식 소프트웨어 설계처리 장치와, 이 장치에서의 처리방법을 제공하는 것을 목적으로 한다.
본 발명은 상기의 목적을 달성하기 위해, 나누어 소프트웨어의 총괄적인 설계처리를 제어하는 중앙설계제어부와, 조립식 소프트웨어 설계부품을 적재하기 위한 설계부품기억부와, 조립식 소프트웨어 설계부품윽 조립하기 위한 설계부품조립부와, 인접한 조립식 소프트웨어 설계부품들을 묶어서 추상화시키기위한 설계부품추상화부와, 조립된 소프트웨어 설계부품을 분해 제거하기 위한 설계 부품분해부와, 네트워크상에서 다수의 설계자가 협력하여 설계처리할 수 있도록 해 주는 설계부품전송관리부와, 멀티미디어적인 소프트웨어 설계처리가 가능하도록 해주는 멀티미디어설계처리부와, 가상현실 환경에서 소프트웨어 설계처리가 가능하도록 해주는 가상현실설계처리부와, 설계단계와 프로그램 코드 구현단계와의 신호변환(forwardand reverse engineering)을 지원하는 설계구현상호변환부의 9부분으로 구성되는 조립식 소프트웨어 설계처리 장치를 구비하고 있다.
이하, 첨부된 도면을 참조하여 본 발명의 세부구현 방법을 설명하기로 한다.
제1도는, 본 발명의 핵심 장치인 조립식 소프트웨어 설계처리 장치의 블록도를 나타낸 것이며, 조립식 소프트웨어 설계처리를 총괄하고 있는 중앙설계제어부(101)는, 설계부품기억부(102)와, 설계부품조립부(103)와, 설계부품추상화부(104)와, 설계부품분해부(105)와, 설계부품전송관리부(106)와, 멀티미디어설계처리부(107)와, 가상현실설계처리부(108)와, 설계구현상호변환부(109)로 각각 연결되어 있다.
본 발명인 조립식 소프트웨어 설계처리 장치에는, 전원이 들어가면, 조립식 소프트웨어 설계처리를 총괄제어하기 위한 중앙설계제어부가 총괄적인 설계제어 작업을 행하기 시작하는 제1단계와, 중앙설계제어부가 보조기억장치로부터 설계부품기억부까지 조립식 소프트웨어 설계부품의 적재작업을 행하는 제2단계와, 설계부품조립부가 규격화 및 표준화된 조립식 소프트웨어 설계부품으로 조립작업을 행하는 제3단계와, 설계부품추상화부가 조립된 소프트웨어 설계부품 속에서 관련성이 있는 것들을 묶어서 추상화시키는 추상화작업을 행하는 제4단계와, 설계부품분해부가 조립된 소프트웨어 설계부품들 중에서 블필요하게 된 부품의 분해제거를 위한 분해작업을 행하는 제5단계와, 설계부품전송관리부가 네트워크상에서의 다수의 설계자에 의한 협력설계처리를 위한 전송관리제어작업을 행하는 제6단계와, 멀티미디어 설계처리부가 멀티미디어적인 소프트웨어 설계처리작업을 행하는 제7단계와, 가상현실설계처리부가 가상현실환경에서의 소프트웨어 설계처리를 위한 가상현실제어작업을 행하는 제8단계와, 설계단계와 프로그램코드 구현단계와의 상호변환(forward and reverse engineering)을 지원하는 변환작업을 행하는 제9단계를 구비하고 있다.
본 발명의 핵심장치인 조립식 소프트웨어 설계처리 장치에 의한 소프트웨어 설계처리의 방법을 기능별로 설명하면, 조립식 스프트웨어의 설계부품을 영상표시용기억장치에 자동적으로 조립해넣고 설계도가 영상표시화면에 그려지는 효과를 내어주는 제1기능과, 작성된 소프트웨어 설계도 속에 새롭게 삽입하고싶은 소프트웨어 부품이 있는 경우, 이 부품의 삽입위치를 자동적으로 인식하여 지정하는 제2기능과, 작성된 설계도 속에서의 제2기능에 의해 인식된 삽입위치에 새로운 소프트웨어 부품을 자동적으로 삽입하여 정확하게 조립해넣는 제3기능과, 새로운 소프트웨어 부품이 삽입됨과 동시에 소프트웨어 설계도의 전체 설계부품들을 자동적으로 재정돈하여 주는 제4기능과, 소프트웨어 설계도로부터 추상화시키려고 하는 범위를 구조별 또는 기능별로 자동적으로 인식하여 지정하는 제5기능과, 제5기능에 의해 인식 지정된 범위를 새로운 구조부품으로 추상화시키는 제6기능과, 삭제하려고 하는 구조부품 또는 기능부품의 범위를 자동적으로 인식하여 지정하는 제7기능과, 제7기능에 의해 인식지정된 범위의 부품을 설계도로부터 자동적으로 분해분리하여 제거하는 제8기능과, 제8기능에 의해 특정 소프트제어부품이 분해제거됨과 동시에 소프트웨어 설계도의 전체부품들을 자동적으로 재정돈하는 제9기능과, 소프트웨어 설계도의 명세부분의 앞부분을 지정하면 자동적으로 라인의 끝까지 범위를 인식하여 원하는 소프트웨어 설계도의 부분에 대한 이동, 복사, 삭제, 추가, 변경 등의편집을 자동적으로 해주는 제10기능과, 소프트웨어 설계부품들의 사이에 블록부품을 조립해넣어 새로운 기본부품을 추가 조립할 수 있도록 하는 제11기능과, 설계도에서 개인루틴이 서브루틴 등과 같은 하위 모듈을 계층적으로 가지도록 설계되는 경우에 상위계층의 설계도 모듈의 호출지점을 자동적으로 인식하는 제12기능과, 제12기능에 의해 자동적으로 인식된 상위 모듈의 호출지점으로부터 하위계층의 설계도 모듈의 목적지점의 시작부분을 자동적으로 인식하는 제13기능과, 상위계층의 모듈로부터 제13기능에 의해 자동적으로 인식된 하위계층의 설계도 모듈의 시작부분까지, 그 하위계층의 설계도 모듈이 상위계층의 모듈과 동일한 파일에 있는가 여부에 관계없이 자동적으로 찾아가는 제 14기능과, 제14기능에 의해 상위모듈로부터 하위 모듈까지 찾아갈 때 상위 모듈 호출지점을 기억하여 놓고나서 상위모듈의 처리가 끝난 뒤 상인모듈의 호출지점으로 그 상위계층의 설계도 모듈이 하위계층의 모듈과 동일한 파일에 있는가 여부에 관계없이 역추적해 되돌아갈 수 있는 제15기능과, 하위 모듈의 처리가 끝난 뒤 상위 모듈의 호출지점으로 되돌아갈 때, 단계를 밟지않고, 무조건 최초로 호출해준 상위모듈의 호출지점으로 그 상위계층의 설계도 모듈이 하위계층의 모듈과 동일한 파일에 있는가여부에 관계없이 역추적하여 되돌아가는 것을 가능하게 하는 제16기능과, 조립식 소프트웨어 설계 부품속에 원하는 형태나 규격의 소프트웨어 설계부품을 추가로 제작하여 등록하는 것을 가능하게 하는 제17기능과, 설계도상의 모듈이름이나 형상을 인식하여 모듈의 기능이나 용도 등을 영상, 음성 등의 멀티미디어로 설명하여 모듈로 직접가지않더라도 그 모듈의 기능이나 사용법 등을 용이하게 습득할 수 있도록 하는 제18기능과, 설계도의 제어구조의 실행상황을 모듈단위로 애니메이션적으로 동작시켜 관찰할 수 있도록해주던가, 모듈단위의 테스트 등을 통하여 발견되는 에러 등의 상황을 음성, 영상 등으로 알려주는 등의 멀티미디어적인 방법에 의한 모듈의 테스트가 가능하게 적도록 하는 제19기능과, 설계도가 종래와 같이 텍스트 위주로 작성되지 않고 멀티미디어방식으로 작성될 수 있도록 음성, 영상 등의 멀티미디어 데이터의 입출력 및 부품 등록, 조립, 분해, 가공 등을 행하는 제20기능과, 설계도 상에서 추상화된 개요만을 자동으로 추출하여 재구성하는 제21기능과, 설계도의 명세를 음성으로 읽어낼 수 있는 제22기능과, 설계처리를 종래와 같이 1인이 1개씩 작성하는 방식이이나라 통신망상에서 다수의 사람들이 동시 다중으로 설계처리가능하게 하는 제23기능과, 설계부품의 조립 및 분해를 포함하는 제반 작업 및 테스트에 있어서, 가상현실환경을 형성하여 가상의 3차원 입체환경 속에서 설계부품들을 입체적으로 보면서 가상적으로 직접 만져서 취급하던가, 느끼면서 설계작업을 행할 수 있도록 하는 제24기능과, 설계단계로부터 프로그램코드를 생성(code generation)구현하는 순공학(forward engineering)작업 및, 프로그램 코드단계로부터 설계복원을 실현하는 역공학(reverse engineering)작업을 행할 수가 있는 제25기능 등을 구비한다.
본 발명의 핵심장치인 조립식 소프트웨어 설계처리장치가 보유하고 있는 각 기능의 구현작업은 조립식 소프트웨어 설계처리장치에 내장되어 있는 중앙설계제어부가 총괄제어를 담당하고, 그밖의 내장장치부를 필요에 따라 제어하여 행한다.
제2-1도 및 제2-2도는 본 발명의 핵심장치인 조립식 소프트웨어 설계처리 장치가 보유하고 있는 각 기능의 구현처리 방법을 본 발명의 방법에 의해 나타낸 설계도의 예이다.
제3-1도 및 제3-2도는 본 발명에 의한 조립식 소프트웨어 설계를 위한 기본부품의 예를 나타난 것으로 제3-1도는 화면상에서 영문자 1개의 크기에 해당하는 반각기본부품을 의미하며 각 부품은 현재까지 공백(space)을 의미하는 A1_1부품으로부터 A1_16까지의 반각기본부품이 만들어기 등록되어 있으며, 새로운 반각기본부품이 만들어질 때에는 언제라도 반각기본부품 번호를 추가하여 새로운 반각기본부품을 계속적으로 등록하여 사용가능하도록 되어있는 특징을 보유하고 있다.
제3-1도의 A1_1의 빈칸반각기본부품은 소프트웨어 설계도를 조립식으로 작성함에 있어서 여백을 메꾸어 설계도의 전체적인 균형을 유지해 주기 위한 반각기본부품이다. 즉, 건물을 지음에 있어서, 철근과 철근 사이를 콘크리트로 메꾸어주듯이, 설계도의 빈칸을 메꾸어주기 위한 부품이다.
제3-1도의 A1_2 내지 A1_14의 반각기본부품은 일종의 건물을 짓기위한 철근에 해당하는 부품이며, 이들 선문자형태의 부품을 조립하여 소프트웨어의 전반적인 설계의 구조의 틀(frame)을 만들어나가게 된다. 제3-1도의 A1_15는 영어대문자 'T'에 해당하는 알파벳반각기본부품으로 고속도로를 달려가는 도중에 길이 갈라질 때의 표지판과 같은 역할을 하며, 설계도의 흐름이 갈라질 때, 어떠한 조건을 설정하여 그 조건에 일치(True)될 때에 분기가 발생함을 나타내 주고자 할 때 조립하여 사용되는 분기표시반각기본부품이다. 제3-1도의 A1_16은 숫자(number) 0 내지 9를 의미하는 'n'으로 표시되고 있으며, 이 반각기본부품은 설계의 흐름이 예외처리(exception handling) 등에 의해 일종의 프로그램의 goto문이라던가,break문에 해당하는 건너뛰기가 발생할 때에 건너뛰기의 단계를 표시하기 위해 사용되는 건너뛰기반각기본부품이다. 실제로는 이 'n'은 건너뛰기의 단계에 해당하는 숫자로 바뀌어서 표시되게 된다.
제3-2도는 화면상에서 한글이나 한자 한 개의 크기에 해당하는 전각기본부품을 뜻하며,각 전각기본부품은 잇따름처리의 추상화에 사용되는 A2_1부품으로부터 설계도의 작도가 페이지를 넘어서 계속되는 경우에 페이지의 연결을 표시하기 위해 사용되는 A2_14부품에 이르기까지 14개의 전각기본부품이 만들어져 조립식 소프트웨어 설계용 기본부품으로 등록되어 있으며, 제3-1도의 A1_1내지 A1_16의 반각기본부품과 동일하게 새로운 전각기본부품이 만들어질 때에는 언제라도 전각기본부품번호를 추가하여 새로운 전자기본부품을 계속적으로 등록하여 사용할 수 있도록 되어있는 특징을 가지고 있다. 예를 들어서, 제3-1도의 A1_15의 부품의 'True'를 의미하는 'T'자를 이에 상당하는 '참'이라는 한글이나 진실이라고 하는 의미를 갖는 '眞' 또는, 이것과 반대되는 뜻을 가진 거짓을 의미하는 '거'라든가 '僞' 등의 글자를 사용하려고 할 때에는, 이들 문자는 전각문자이므로 반각기본부품으로 등록되어 있는 제3-1도의 A1_15의 부품과는 별도로 제3-2도의 전각기본부품으로 추가로 등록해주면 되며, 새로운 개념에 대한 표현 등의 필요에 의해 새로운 전각기본부품이 필요하게 되는 경우에는 언제라도 전각크기인가 반각크기인가에 따라 각각 그에 맞는 기본부품으로 등록해 줄 수 있다. 또한, 크기에 있어서 전각크기나 반각크기보다 크기가 크거나 작은 부품이 필요하게 되는 경우에는, 별도의 크기에 따라 A3, A4, ...등으로 기본부품번호를 확장하여 계속해서 새로운 크기의 형식화 및 규격화된 조립식 기본부품을 등록해 주면 된다.
이러한 조립식 기본부품의 등록이 가능하도록 확장성을 고려했다는 것은, 결국 어떠한 고정되고 제한된 형태의 모양만으로 조립식 기본부품의 등록을 하는 식의 한정된 개념으로부터 탈피하여, 필요시에 음성이라던가 영상 등과 같은 멀티미디어의 부품까지도 추가 등록시킬 수 있으며, 이와 같은 멀티미디어 부품도 규격화 및 표준화처리를 통하여 가공 조립하여 추상화시키거나, 분해하여 구체화시킬 수 있도록 적용하고 있다는 것을 뜻하는 것이며, 더 나아가서는, 가상현실(virtual realit)기법을 적용하여 이러한 조립식 기본부품을 가상입체공간 환경속에서 직접 만지거나, 보거나, 느끼거나, 하면서 조립 및 분해하기 위한 조립식 소프트웨어 설계부품 및 이 조립 및 분해를 위한 방법에도 적용할 수 있다는 것을 뜻한다고 설명할 수 있는 것도, 이러한 부품화의 원리에서 당연히 이해될 수 있는 것이다.
제4-1도 내지 제4-7도는 상기의 제3-1도 및 제3-2도 설명에서 언급한 바와 같은 모래나 시멘트에 해당하는 기본부품들을 결합하여 시멘트 벽돌에 해당하는 블록(block)으로 추상화시켜서 새로운 블록부품(block components)으로 만든 것으로서, 제4-1도의 B1_1 내지 B1_5의 블록부품은 작성되는 소프트웨어 설계도가 주모듈(main module)인가 부모듈(sub module)인가를 나타내주는 건축물의 기초공사에 해당하는 설계바탕을 형성해주는데 사용되는 바탕블록부품을 뜻하며 제4-2도의 B2_1내지 B2_7의 블록부품은, 소프트웨어 설계도의 각 구조패턴의 종류를 표시함과 동시에 구조의 목적을 우측에 기술할 수 있도록 해주는 목적블록부품을 뜻하며, 제4-3도의 B3_1내지 B3_4의 블록부품은, 설계도의 구조부품이 어떤 조건에 의해 처리를 행하는 if~then이라던가 for~do 등과 같은 조건을 갖는 구조부품일 경우에 이것과 동일한 조건을 표시할 수 있도록 하는 조건블록부품을 뜻하고, 제4-4도의 B4_1내지 B4_9의 블록부품은 소프트웨어 설계도의 각 구조의 종류에 따라 구조의 처리부분이 시작됨을 알려주기 위한 도입부에 해당하는 처리앞블록부품을 뜻하면, 제4-5도의 B5_1내지 B5_7의 블록부품은 소프트웨어설계도의 각 구조부품의 구체적인 처리를 기술할 수 있도록 하는 처리속블록부품을 뜻하며, 제4-6도의 B6_1내지 B6_12의 블록부품은 소프트웨어 설계도의 각 구조부품의 처리부분이 마감되어 흐름이 다른 구조부품, 기본부품 등으로 넘어가는 것을 나타내어 주기 위한 각 구조부품의 종결부를 표현해주기 위한 처리끝블록부품을 뜻하며, 제4-7도의 B7_1 내지 B7_6의 블록부품은 건물을 조립식으로 건축하거나 분해할 때, 보수하기 위한 자재가 필요하듯이, 소프트웨어 설계도의 각 구조부품 또는 블록부품 등이 조립되거나 추상화되거나 분해되는 과정에서 각 구조의 종류에 따라 허술해지는 부분을 소프트웨어적으로 보완하여 보수하기 위한 블록보수부품을 뜻한다.
상기의 제4-1도 내지 제4-7도의 블록부품도 제3-1도 내지 제3-2도의 기본부품과 동일하게, 필요시에는 언제라도 부품번호를 추가하여 새로운 부품을 추가로 등록할 수 있도록 하여 장래의 확장에 대비할 수 있도록 되어 있다.
제5-1-A도 내지 제5-4-I도는 제4-1도 내지 제4-7의 블록부품을 서로 조립하여 새로운 구조로 추상화시켜 만든 구조부품(structure components)의 예를 나타낸 것으로, 제5-1-A도 내지 제5-1-B도는 작성되는 소프트웨어 설계도가 주모듈(main module)인가 부모듈(sub module)인가를 나타내어 주는 건축물의 기초공사에 해당하는 설계바탕을 형성해주는데 사용되는 바탕구조부품을 뜻하며, 제 5-1-A도의 C1_1은 만들어지는 소프트웨어 설계도가 주모듈인 경우의 기초 바탕을 형성해주는데 사용되는 주모듈바탕구조부품을 뜻하며, 제5-1-B도의 C1_2는 만들어지는 소프트웨어 설계도가 부모듈인 경우의 기초 바탕을 형성해주는데 사용되는 부모듈바탕구조부품을 뜻한다. 부모듈에서 다시 다른 부모듈을 표현할 때에도 제5-1-B도의 부모듈바탕구조부품으로 바탕을 형성해주며, 각각의 부모듈의 바탕구조의 위에는 각각의 모듈의 이름을 써줌으로써 부모듈의 개별적인 구별이 가능하게 되는 것이다.
제5-2-A내지 제5-2-M도는, 한번에 한 개씩의 처리를 행하는 단일처리(uniprocessing)를 표현해주는데 사용되는 단일처리구조부품을 뜻하며, 이를 세부적으로 설명하자면, 제5-2-A도의 C2_1은 처리가 시간적으로 연속하여 차례대로 처리될 경우에 이것을 추상화하여 구조로 표현해주는 한잇따름구조(sequential structure)부품을 뜻하며, 제5-2-B도의 C2_2는 조건이 일치될 때, 흐름이 갈라져서 특별한 처리를 해주도록 하는 구조를 표현해주는 한가림구조(if~then structure)부품을 뜻하며, 제 5-2-C도의 C2_3은 조건을 2가지로 검사하여 그것에 의해 다른 처리를 해주도록 하는 구조를 표현해주는 두가림구조(if~then~else structure)부품을 뜻하며, 제5-2-D도의 C2_4는 조건을 세가지이상으로 검사하여, 그에 따라 다른 처리를 해주도록 하는 구조를 표현해주는 여러가림구조(case structure)부품을 뜻하며, 제5-2-E도의 C2_5는 되풀이하여 처리되는 되풀이구조(iteration structure)에서 해당 구조를 빠져나가는 검사를 구조의 앞부분에서 행하는 구조를 표현해주는 앞끝되풀이구조(while~do structure)부품을 뜻하며,제5-2-F도의 C2_6은 되풀이하여 처리되는 되풀이 구조에서 해당 구조를 빠져나가는 검사를 구조의 중간부분에서 행하는 구조를 표현해주는 사이끝되풀이구조(Knuth-Zahn-Haherman structure)부품을 뜻하며, 제5-2-G도의 C2_7은 되풀이하여 처리되는 되풀이구조에서 해당 구조를 빠져나가는 검사를 구조의 끝부분에서 행하는 구조를 표현해주는 뒤끝되풀이구조(do~until structure)부품을 뜻하며, 제5-2-H도의 C2_8은 되풀이되는 회수를 제어하여 구조를 빠져나가는 시점을 미리 알고 구조로 들어갈 수 있는 구조를 표현해주는 끝아는되풀이구조(for~do structure)부품을 뜻하며, 제5-2-I도의 C2_9는 시스템의 이상 발생시에 이상이 일어난 부품에 대한 표시 등을 자동적으로 해주는 구조를 표현해주는 한잇따름이상구조(sequential illness handling structure)부품이며, 제5-2-J의 C2_10은 조건을 한가지로 검사하여 키보드입력잘못이라던가 특수한 조건처리 등과 같은 비상적인 처리를 하기위한 구조를 표현해주는 한가림비상구조(if~then exception handling structure)부품을 뜻하며, 제5-2-K도의 C2_11은 조건을 두가지로 검사하여 그에 따라 다른 비상적인 처리를 하기 위한 구조를 표현해주는 두가림비상구조(if~then~else exception handling structure)부품을 뜻하며, 제5-2-L도의 C2_12는 조건을 세가지이상으로 검사하여 그에 따라 다른 비상적인 처리를 하기 위한 구조를 표현해주는 여러가림비상구조(case exception handling structure)부품을 뜻하며, 제5-2-M도의 C2_13은 자료를 기능이나 종류별 등과 같이 묶어서 추상화시켜 선언하는 것 등과 같은 처리를 하기 위한 구조를 표현해주는 자료추상화구조(data abstraction structure)부품을 뜻한다.
제5-3-A도 내지 제5-3-R도는 한번에 두가지 이상의 일(task)을 복합적으로 처리하는 병렬처리라든가 동시처리 등과 같은 다중처리를 표현해주는데 사용되는 다중처리구조(multi-processing structure)부품을 뜻하며, 이를 세부적으로 설명하자면, 제5-3-A도의 C3_1은 2가지의 연속적인 처리가 동시에 처리될 경우에 이를 추상화하여 구조로 표현해주는 두겹잇따름구조(double sequential structure)부품을 뜻하며, 제5-3-B도의 C3_2는 3가지이상의 연속적인 처리가 동시에 처리될 경우에 이를 추상화하여 구조로 표현해주는 여러겹잇따름구조(multiple sequential structure)부품을 뜻하며, 제5-3-C도의 C3_3은 두가지의 조건을 동시에 점검하여, 조건에 일치되는 처리로 흐름이 동시에 갈라져서 복합적으로 특별한 처리를 해주도록 하는 구조를 표현해주는 두겹가림구조(double if~then structure)부품을 뜻하며, 제5-3-D도의 C3_4는 3가지이상의 조건을 동시에 점검하여 조건에 일치되는 처리로 흐름이 동시에 갈라져서 복합적으로 특별한 처리를 해주도록 하는 구조를 표현해주는 여러겹가림구조(multiple if~then structure)부품을 뜻하며, 제5-3-E도의 C3_5는 되풀이하여 처리되는 되풀이구조(iteration structure)에서 해당 구조를 빠져나가는 검사를 구조의 앞부분에서 행하는 구조를 표현해주는 앞끝되풀이구조(while~do structure) 2개가 동시에 복합적으로 처리되는 것을 표현해주는 두겹앞끝되풀이구조(double while~do structure)부품을 뜻하며, 제5-3-F도의 C3_6은 되풀이하여 처리되는 되풀이 구조에서 해당 구조를 빠져나가는 검사를 구조의 중간부분에서 행하는 구조를 표현해주는 사이끝되풀이구조(Knth-Zahn-Haerman structure) 2개가 동시에 복합적으로 처리되는 것을 표현해주는 두겹사이끝되풀이구조(double Knuth-Zahn-Haberman structure)부품을 뜻하며, 제 5-3-G도의 C3_7은 되풀이하여 처리되는 되풀이구조에서 해당 구조를 빠져나가는 검사를 구조의 끝부분에서 행하는 구조를 표현해주는 뒤끝되풀이구조(do~until structure) 2개가 동시에 복합적으로 처리되는 것을 표현해주는 두겹뒤끝되풀이구조(double do~until structure)부품을 뜻하며, 제5-3-H도의 C3_8은 되풀이하여 처리되는 되풀이구조(iteration structure)에서 해당 구조를 빠져나가는 검사를 구조의 앞부분에서 행하는 구조를 표현해주는 앞끝되풀이구조(while~do structure) 3개이상이 동시에 복합적으로 처리되는 것을 표현해주는 여러겹앞끝되풀이구조(multiple while~do structure)부품을 뜻하며, 제5-3-I도의 C3_9는 되풀이하여 처리되는 되풀이 구조에서 해당 구조를 빠져나가는 검사를 구조의 중간부분에서 행하는 구조를 표현해주는 사이끝되풀이구조(Knuth-Zahn-Haberman structure) 3개이상이 동시에 복합적으로 처리되는 것을 나타내는 다중사이끝되풀이구조(multiple Knuth-Zahn-Haberman structure)부품을 뜻하며, 제5-3-J도의 C3_10은 되풀이하여 처리되는 되풀이 구조에서 해당 구조를 빠져나가는 검사를 구조의 끝부분에서 행하는 구조를 표현해주는 뒤끝되풀이구조(do~until sturcture)3개이상인 동시에 복합적으로 처리되는 것을 표현해주는 다중뒤끝되풀이구조(multiple do~until structure)부품을 뜻하며, 제5-3-K도의 C3_11은 되풀이되는 회수를 제어하여 구조로부터 나가는 시점을 사전에 알고 구조로 들어갈 수가 있는 구조를 표현해주는 끝아는되풀이구조(for~do structure)2개가 동시에 복합적으로 처리되는 것을 표현해주는 겹끝아는 되풀이구조(double for~do structure)부품을 뜻하여, 제5-3-L도의 C3_12는 되풀이되는회수를 제어하여 구조로부터 나가는 시점을 사전에 알고 구조로 들어갈 수 있는 구조를 표현해주는 끝아는되풀이구조(for~do structure)3개이상이 동시에 복합적으로 처리디는 것을 표현해주는 다중끝아는되풀이구조(multiple for~do structure)부품을 뜻하며, 제5-3-M도의 C3_13은 시스템의 이상발생시에 이상이 일어난 부분에 대한 표시등을 자동적으로 하는 구조를 표현해주는 잇따름이상구조(sequential illness handling structure)2개가 동시에 복합적으로 처리되는 것을 표현해주는 겹잇따름이상구조(double sequential illness handling structure)부품을 뜻하며, 제5-3-N도의 C3_14는 시스템의 이상발생시에 이상이 일어난 부분에 대한 표시등을 자동적으로 하는 구조를 표현해주는 잇따름이상구조(sequential illness handling structure)ㄷ개이상이 동시에 복합적으로 처리되는 것을 표현해주는 다중잇따름이상구조(multiple sequential illness handling structure)부품을 뜻하며, 제5-3-O도의 C3_15는 조건을 1종류로 검사하여 키보드입력 오류라든가 특수한 조건처리등과 같은 비상적인 처리를 하기위한 구조를 표현해주는 한가림비상구조(if~then exception handling structure)2개가 동시에 복합적으로 처리되는 것을 표현해주는 두겹한가림비상구조(double if~then exception handling structure)부품을 뜻하며, 제 5-3-P도의 C3_16은 조건을 1종류로 검사하여 키보드입력잘못이라든가 특수한 조건처리 등과 같은 비상적인 처리를 하기위한 구조를 표현해주는 한가림비상구조(if~then exception handling structure)3개이상이 동시에 복합적으로 처리되는 것을 표현해주는 여러겹한가림비상구조(multiple if~then exception handling structure)부품을 뜻하며, 제5-3-Q도의 C3_17은 자료를 기능이나 종류별 등과 같이묶어서 추상화시켜 선언하는 것 등과 같은 처리를 행하기 위한 구조를 표현해주는 자료추상화구조(data abstraction structure) 2개가 동시에 복합적으로 처리되는 것을 표현해주는 두겹자료추상화구조(double data abstraction structure)부품을 뜻하며, 제5-3-R도의 C3_18은 자료를 기능이나 종류별 등과 같이 묶어서 추상화시켜 선언하는 것 등과 같은 처리를 행하기 위한 구조를 표현해주는 자료추상화구조(data abstraction structure) 3개이상이 동시에 복합적으로 처리되는 것을 표현해주는 여러겹자료추상화구조(multiple data abstraction structure)부품을 뜻한다. 상기와 같은 제5-1-A도 내지 제5-3-R도의 구조부품도 차후 새로운 구조부품이 만들어질 때에는 새롭게 번호를 추가하여 구조부품으로 등록할 수 있도록 되어 있다.
제5-4-A도 내지 제5-4-I도는 상기와 같은 제5-1-A 내지 제5-3-R도에서의 구조부품이 확장될 경우에, 이의 확장보수를 지원하기 위해 만들어진 구조보수(structure maintenance)부품을 뜻하며, 이를 세부적으로 설명하자면, 제5-4-A도의 C4_1은 제5-2-D도의 C2_4의 여러가림구조(case structure)부품에서 가림수를 확장하려고 할 때에 사용되는 여러가림구조보수부품을 뜻하며, 제5-4-B도의 C4_2는 제5-2-L도의 C2_12의 여러가림비상구조(case exception handling structure)부품에서 가림수를 확장하려고 할 때에 사용되는 여러가림비상구조보수부품을 뜻하며, 제5-4-C도의 C4_3은 제5-3-B도의 C3_2의 여러겹한잇따름구조(multiple sequential structure)부품과 제5-3-N도의 C3_14의 여러겹잇따름이상구조(multiple sequential structure)부품과 제5-3-N도의 C3_14의여러겹잇따름이상구조(multiple sequential illness handling structure)부품과, 제5-3-R도의 C3_18의 여러겹자료추상화구조(multiple data abstraction structure)부품에서 잇따름수를 확장하려고 할 때에 사용되는 여러겹잇따름구조보수부품을 뜻하며, 제5-4-2도의 C4_4는 제5-3-D도의 C3_4의 여러겹한가림구조(multiple if~then structure)부품에서 가림수를 확장하려고 할 때에 사용되는 여러겹한가림비상구조보수부품을 뜻하며, 제5-4-E도의 C4_5는 제5-3-H도의 C3_8의 여러겹앞끝되풀이구조(multiple while~do structure)부품에서 앞끝되풀이구조수를 확장하려고 할 때에 사용되는 머러겹앞끝되풀이구조보수부품을 뜻하며, 제5-4-F도의 C4_6은 제5-3-I도의 C3_9의 여러겹사이끝되풀이구조(multiple Knuth-Zahn-Haberman structure)부품에서 사이끝되풀이구조수를 확장하려고 할 때에 사용되는 여러겹사이끝되풀이구조보수부품을 뜻하며, 제5-4-C도의 C4_7은 제5-3-J도의 C3_10의 여러겹뒤끝되풀이구조(multiple do~until structure)부품에서 뒤끝되풀이구조수를 확장하려고 할 때에 사용되는 여러곁뒤끝되풀이구조보수부픔을 뜻하며, 제5-4-H도의 C4_8은 제5-3-L도의 C3_12의 여러겹끝아는되풀이구조(multiple for∼do structure)부품에서 끝아는되풀이구조수를 확장하려고 할 때에 사용되는 여러겹끝아는되풀이구조보수부품을 뜻하며, 제5-4-I도의 C4_9는 제5-3-P도의 C3_16의 여러겹한가림비상구조(multiple if~then exception handling structure)부품에서 가림수를 확장하려고 할 때에 사용되는 여러겹한가림비상구조보수부품을 뜻한다. 상기와 같은 제5-4-A도 내지 제5-4-I도의 구조보수(structure maintenance)부품도 필요한 때에는 추가되는 구조에 대한 새로운 구조보수부품을 번호를 추가하여 새롭게 등록할수 있도록 되어 있다.
여기서, 제4-1도 내지 제4-7도의 블록부품의 조립예를 설명하자면, 제4-1도의 B1_1은 제3-1도의 A1_2부품 1개와 A1_8부품1개와 A1_2부품 또 1개와 이어서 A1_1부품 7개가 일렬로 조립되어 구성되는데, A1_2ㆍA1_8ㆍA1_2ㆍ(A1_1)*7 과 같이 표현하고 있으며, 여기에서 'ㆍ'기호는 기본부품 2개를 납땜을 하는 것처럼 붙인 것을 뜻하며, '*'기호는 해당기호가 '*'기호의 옆에 쓰여진 숫자만큼 되풀이되어 결합된 것을 뜻한다. 제4-1도 내지 제4-도의 이외의 블록부품도 제4-1도의 B1_1블록부품과 동일한 형태로 제3-1도의 기본부품을 결합하여 구성하면 되며, 제5-1-A도 내지 제5-4-I도의 구조관련부품은 제4-1도 내지 제4-7도의 블록부품을 상하로 결합하여 구성하면 된다.
제6-1-A 내지 제6-3-A도는, 본 발명에 사용되는 조립식 소프트웨어 설계 부품을 가지고, 실제로 조립, 추상화 및 분해하는 방법에 대해서 기술한 것이다.
제6-1-A도 내지 제6-1-D도는 본 발명에 사용되는 조립식 소프트웨어 설계 부품을 가지고 실제로 조립하여 소프트웨어를 설계하는 방법의 실제 조립예를 나타낸 것이다 제6-1-A도는 제5-1-A도의 C1_1구조부품을 주모듈(main module)의 바탕구조로서 표현한 것이며, 제6-1-B도는 제6-1-A도에 제5-2-A도의 C2_1의 한잇따름구조부품을 조립해 넣은 예를 표현한 것이며, 제6-1-C도는 제6-1-B도에 제5-2-B도의 C2_2의 한가림구조부품을 조립해 넣은 예를 표현한 것이며, 제6-1-D도에 제5-2-E도의 C2_5의 앞끝되풀이구조부품을 조립해 넣은 예를 표현한 것이다.
상기한 바와 같이 계속 조립해 나감으로서 소프트웨어 설계도의 구조를 조립식으로 완성해나갈 수가 있다.
제6-2-A도는 본 발명에 사용되는 조립식 소프트웨어 설계 부품을 가지고 실제로 조립한 내용들 중에서 관련있는 것들을 묶어서 새로운 구조로 조립하여 추상화시키는 방법의 실제 조립예를 표현한 것이다.
제6-2-A도는 제6-1-D도로부터 제5-2-B도의 C2_2의 한가림구조부품과 제5-2-E도의 C2_5의 앞끝 되풀이구조부품을 묶어서, 제4-7도의 블록보수부품 및 제3-1도의 반각기본부품과 결합하여 새롭게 제5-2-H도의 C2_8의 사이끝되풀이구조부품으로 추상화시킨 예를 표현한 것이다.
상기한 바와 같이 필요한 구조는 몇 개라도 묶어서 원하는 새로운 구조로 추상화시켜나감으로서 소프트웨어 설계도의 가독성(readability)을 높혀나갈 수 있다.
제6-3-A도는 본 발명에 사용되는 조립식 소프트웨어 설계 부품을 가지고 실제로 조립한 내용들 중에서 필요없게 된 부분을 분해하여 삭제하는 방법의 실제 분해예를 표현한 것이다.
제6-3-A도는 제6-1-A도에서 추상화하여 표현된 예에서 다시 추상화시키는 것이 바람직하지않다고 판단되어 추상화표현된 제5-2-H도의 C2_8의 사이끝되풀이구조부품을 분해 삭제하여 제6-1-D도와 같은 상태로 회복시킨 예를 표현한 것이다.
제6-3-A도의 결과로부터도 이해되는 바와 같이, 분해 삭제는, 불필요하게 된 부품을 소프트웨어적으로 단순히 삭제하고, 삭제되어 빈 자리를 남은 부품들로 채우도록 함으로서 간단하게 구현할 수가 있다.
본발명은, 자동화된 장치와 방법으로 소프트웨어 설계처리를. 행하기 때문에, 소프트웨어 설계부품의 조립, 추상화, 분해, 취급, 전달, 변환 등의 제반 소프트웨어 설계처리 및 유지보수를 간단히 행할 수가 있으며, 소프트웨어 분야에서의 개발생산성 및 유지보수성을 향상시킬 수가 있으며, 종래보다 효과적으로 인적, 시간적 및 물적인 제반 경비의 절감 및 경쟁력의 강화 등 산업상에 이용될 수가 있다.
제1도는 본 발명의 핵심장치인 조립식 소프트웨어 설계부품과 그 조립 및 분해를 위한 설계처리 장치의 블록도.
101‥‥‥중앙설계제어부, 102‥‥‥설계부품기억부, 103‥‥‥설계부품조립부,
104‥‥‥설계부품추상화부, 105‥‥‥설계부품분해부, 106‥‥‥설계부품전송관리부,
107‥‥‥멀티미디어설계처리부, 108‥‥‥가상현실설계처리부, 109‥‥‥설계구현상호변환부.
제2-1도 내지 제2-2도는 본 발명의 핵심장치인 조립식 소프트웨어 설계처리 장치가 보유하고 있는 각 기능의 구현처리 방법을 본 발명의 방법으로 조립식으로 그려서 나타낸 설계도의 예시도.
제3-1도 내지 제3-2도는 본 발명에 의한 조립식 소프트웨어 설계처리를 위한 기본부품(basic components)의 예시도.
제3-1도‥‥‥반각기본부품의 예시도, 제3-2도‥‥‥전각기본부품의 예시도
제4-1도 내지 제4-7도는 본 발명에 의한 조립식 소프트웨어 설계처리를 위한 기본부품을 조립하여 구성한 블록부품(block components)의 예시도.
제4-1도‥‥‥기초블록부품의 예시도, 제4-2도‥‥‥목적블록부품의 예시도,
제4-3도‥‥‥조건블록부품의 예시도, 제4-4도‥‥‥처리앞블록부품의 예시도,
제4-5도‥‥‥처리속블록부품의 예시도, 제4-6도‥‥‥처리후블록부품의 예시도,
제4-7도‥‥‥블록보수부품의 예시도.
제5-1-A도 내지 제5-4-I도는 본 발명에 의한 조립식 소프트웨어 설계처리를 위한 블록부품을 조립하여 구성한 구조부품(structure components)의 예시도.
제5-1-A도 내지 제5-1-B도는 기초구조부품(basic structure components)의 예시도,
제5-2-A도 내지 제5-2-M도는 단일처리구조부품(uniprocessing structure components)의 예시도,
제5-3-A도 내지 제5-3-R도는 다중처리구조부품(multiprocessing structure components)의 예시도,
제5-4-A도 내지 제5-4-I도는 구조보수부품(structure maintenance components)은 예시도.
제6-1-A도 내지 제6-3-A도는 본 발명에 사용되는 조립식 소프트웨어 설계부품을 가지고 실제로 조립, 추상화 및 분해하는 방법의 예시도.
제6-1-A도 내지 제6-1-D도는 설계부품 속에서 구조부품을 조립하는 방법의 예시도,
제6-2-A도는 설계부품 속에서 구조부품을 추상화하는 방법의 예시도,
제6-3-A도는 설계부품 속에서 구조부품을 분해제거하는 방법의 예시도.

Claims (30)

  1. 소프트웨어 설계를 조립식으로 행하기 위한 조립식 소프트웨어 설계부품에서, 규격화 및 표준화된 조립식 소프트웨어 설계를 위한 기본부품과,
    기본부품들을 조립하여 만들어지는 블록부품과,
    블록부품들을 조립하여 만들어지는 구조부품을 포함하는 조립식 소프트웨어 설계부품,
  2. 제 1 항에 있어서,
    상기 기본부품은,
    조립식 소프트웨어 설계도의 빈칸을 메워주기 위한 빈칸반각기본부품과,
    조립식소프트웨어 설계도의 전반적인 구조의 틀(frame)을 만들어가는 선문자 형태의 다수의 반각기본부품과,
    설계도의 흐름에 분기가 발생하는 것을 표현해주는 경우에 조립하여 사용되는 분기표시반각기본부품과,
    숫자 0 내지 9를 뜻하는 n으로 표시되어, 건너뜀의 단계를 표시하기 위해 사용되는 건너뛰기반각기본부품과,
    다수의 전각기본부품을 포함하는 조립식 소프트웨어 설계부품.
  3. 제 1 항에 있어서,
    상기 블록부품은,
    소프트웨어 설계바탕을 형성하기 위해 사용되는 바탕블록부품과,
    소프트웨어 설계도의 각 구조패턴의 종류를 표시함과 동시에 구조의 목적을 우측에 기술할 수 있도록 해주는 목적블록부품과,
    설계도의 구조부품이 조건을 갖는 구조부품인 경우에 조건을 표시해줄 수 있도록 해주는 조건블록부품과,
    설계도의 각 구조의 종류에 따라 구조의 처리부분이 시작되는 것을 알려주기 위한 도입부에 해당하는 처리앞블록부품과,
    설계도의 각 구조의 구체적인 처리를 기술할 수 있도록 하는 처리속블록부품과,
    설계도의 각 구조의 처리부분이 마감되어 흐름이 다른 구조로 넘어감을 나타내어 주기 위한 각 구조의 종결부를 표현해 주기 위한 처리끝블록부품과,
    설계도의 각 구조 또는 블록 등이 조립되거나 추상화되거나 분해되는 과정에서 각 구조의 종류에 따라 허술해지는 부분을 소프트웨어적으로 보완하여 보수해 주기 위한 블록보수부품을 포함하는 조립식 소프트웨어 설계부품.
  4. 제 1 항에 있어서,
    상기 구조부품은,
    설계도가 주모듈인가 부모듈인가를 나타내는 설계바탕을 형성하는데 사용되는 바탕구조부품과, 한번에 한 개씩의 처리를 행하는 단일처리를 표현해주는데 사용되는 다수의 단일처리구조부품과, 두가지이상의 작업을 복합적으로 처리하는 여러겹처리를 표현해 주는 데 사용되는 다수의 여러겹처리 구조부품을 포함하는 조립식 소프트웨어 설계부품.
  5. 제 4 항에 있어서,
    상기 바탕구조부품은,
    설계도가 주모듈일 경우의 기초바탕을 형성해주는 데 사용되는 주모듈 바탕구조부품과, 설계도가 부모듈인 경우의 기초바탕을 형성해주는 데 사용되는 부모듈 바탕구조부품을 포함하는 조립식 소프트웨어 설계부품.
  6. 제 4 항에 있어서,
    상기 단일처리구조부품은,
    처리가 시간적으로 연속하여 차례대로 처리될 경우에 이것을 추상화하여 구조로 표현해 주는 한잇따름구조부품과,
    조건이 일치될 때 흐름이 갈라져서 특별한 처리를 해주도록 하는 구조를 표현해주는 한가림구조부품과,
    조건을 두가지로 검사하여 그에 따라 다른 처리를 해주도록 하는 구조를 표현해주는 두가림구조부품과,
    조건을 세가지이상으로 검사하여, 그에 따라 다른 처리를 해주도록 구조를 표현해주는 여러가림구조부품과,
    되풀이하여 처리되는 되풀이구조에서 해당 구조를 빠져나가는 검사를 구조의 앞부분에서 행하는 구조를 표현해주는 앞끝되풀이구조부품과,
    되풀이되는 구조에서 해당 구조를 빠져나가는 검사를 구조의 중간부분에서 행하는 구조를 표현해주는 사이끝되풀이구조부품과,
    해당 구조를 빠져나가는 검사를 구조의 끝부분에서 행하는 구조를 표현해주는 뒤끝되풀이구조부품과,
    되풀이되는 회수를 제어하여 구조를 빠져나가는 시점을 미리 알고 구조로 들어갈 수 있는 구조를 표현해주는 끝아는되풀이구조부품과,
    시스템의 이상 발생시에 이상이 생긴 부분에 대한 표시를 자동적으로 해주는 구조를 표현해주는 한잇따름이상구조부품과,
    조건을 한가지로 검사하여 그에 따라 비상적인 처리를 하기 위한 구조를 표현해주는 한가림비상구조부품과,
    조건을 두가지로 검사하여 그에 따라 비상적인 처리를 하기 위한 구조를 표현해주는 두가림비상구조부품과,
    조건을 세가지이상으로 검사하여 그에 따라 비상적인 처리를 하기 위한 구조를 표현해주는 여러가림비상구조부품과,
    자료를 추상화시켜 처리를 하기 위한 구조를 표현해주는 자료추상화구조부품을 포함하는 것을 특징으로 하는 조립식 소프트웨어 설계부품.
  7. 제 4 항에 있어서,
    상기의 여러겹처리구조부품은,
    두가지의 연속적인 처리가 동시에 처리될 경우에 이것을 추상화하여 구조로 나타내는 두겹잇따름구조부품과,
    세가지이상의 연속적인 처리가 동시에 처리될 경우에 이것을 추상화하여 구조로 나타내는 여러겹잇따름구조부품과,
    두가지의 조건을 동시에 점검하여 조건에 일치되는 처리에서 흐름이 동시에 갈라져서 복합적으로 특별한 처리를 해주도록 하는 구조를 표현해주는 두겹가림구조부품과,
    세가지이상의 조건을 동시에 점검하여 조건에 일치되는 처리에서 흐름이 등시에 갈라져서 복합적으로 특별한 처리를 해주도록 하는 구조를 표현해주는 여러겹가림구조부품과,
    되풀이하여 처리되는 되풀이구조에서 해당 구조를 빠져나가는 검사를 구조의 앞부분에서 행하는 앞끝되풀이구조 2개가 동시에 복합적으로 처리되는 것을 표현해주는 두겹앞끝되풀이구조부품과,
    되풀이하여 처리되는 되풀이구조에서 해당 구조를 빠져나가는 검사를 구조의 중간부분에서 행하는 사이끝되풀이구조 2개가 동시에 복합적으로 처리되는 것을 표현해주는 두겹사이끝되풀이구조부품과,
    되풀이하여 처리되는 되풀이구조에서 해당 구조를 빠져나가는 검사를 구조의 끝부분에서 행하는 뒤끝되풀이구조 2개가 동시에 복합적으로 처리되는 것을 표현해주는 두겹뒤끝되풀이구조부품과,
    되풀이하여 처리되는 되풀이구조에서, 해당 구조를 빠져나가는 검사를 구조의 앞부분에서 행하는 앞끝되풀이구조 3개이상이 동시에 복합적으로 처리되는 것을 표현해주는 여러겹앞끝되풀이구조부품과,
    되풀이하여 처리되는 되풀이구조에서 해당 구조를 빠져나가는 검사를 구조의 중간부분에서 행하는 사이끝되풀이구조 3개이상이 동시에 복합적으로 처리되는 것을 표현해주는 여러겹사이끝되풀이구조부품과,
    되풀이하여 처리되는 되풀이구조에서 해당 구조를 빠져나가는 검사를 구조의 끝부분에서 행하는 뒤끝되풀이구조 3개이상이 동시에 복합적으로 처리되는 것을 표현해주는 여러겹뒤끝되풀이구조부품과,
    되풀이되는 회수를 제어하여 구조로부터 나가는 시점을 미리 알고 구조로 들어갈 수가 있는 끝아는되풀이구조 2개가 동시에 복합적으로 처리되는 것을 표현해주는 두겹끝아는되풀이구조부품과, 되풀이되는 회수를 제어하여 구조로부터 나가는 시점을 사전에 알고 구조로 들어갈 수가 있는 끝아는되풀이구조 3개이상이 동시에 복합적으로 처리되는 것을 표현해주는 여러겹끝아는되풀이구조부품과,
    시스템의 이상 발생시에 이상이 일어난 부분에 대한 표시등을 자동적으로 하는 한잇따름이상구조 2개가 동시에 복합적으로 처리되는 것을 표현해주는 두겹잇따름이상구조부품과,
    시스템의 이상 발생시에 이상이 일어난부분에 대한 표시등을 자동적으로 하는 한잇따름이상구조 3개이상이 동시에 복합적으로 처리되는 것을 표현해주는 여러겹잇따름이상구조부품과,
    조건을 1종류로 검사하여 키보드입력잘못이나 특수한 조건처리 등과 같은 비상적인 처리를 행하기 위한 한가림비상구조 2개가 동시에 복합적으로 처리되는 것을 표현해주는 두겹한가림비상구조부품과,
    조건을 1종류로 검사하여 키보드입력잘못이나 특수한 조건처리 등과 같은 비상적인 처리를 행하기 위한 한가림비상구조 3개 이상이 동시에 복합적으로 처리되는 것을 표현해주는 여러겹한가림비상구조부품과,
    자료를 기능이나 종류별 등과 같이 묶어서 추상화시켜 선언하는 것등과 같은 처리를 행하기 위한 자료추상화구조 2개가 동시에 복합적으로 처리되는 것을 표현해주는 두겹자료추상화부품과,
    자료를 기능별, 종류별 등과 같이 묶어서 추상화시켜 선언하는 것등과 같은 처리를 행하기 위한 자료추상화구조 3개이상이 동시에 복합적으로 처리되는 것을 표현해주는 여러겹자료추상화부품과,
    종류가 다른 구조부품들을 겹쳐서 새로운 복합적구조로 표현해주는 복합구조부품을 포함하는 것을 특징으로 하는 조립식 소프트웨어 설계부품.
  8. 제 1 항에 있어서,
    상기 조립블록부품의 가림 및 겹처리에 사용되는 부품의 중간부분의 수직선모양의 선은 최 좌우측선의 폭의 중앙부근에 위치하는 것을 특징으로 하는 조립식 소프트웨어 설계부품.
  9. 조립식 소프트웨어 설계처리장치의 작동단계에서,
    조립식 소프트웨어 설계처리를 총괄 제어하는 중앙설계제어부가 총괄적인 설계제어작업을 행하기 시작하는 제1단계와,
    중앙설계제어부가 보조기억장치로부터 설계부품기억부까지 조립식 소프트웨어 설계부품의 적재작업을 행하는 제2단계와,
    설계부품조립부가 규격화 및 표준화된 조립식 소프트웨어 설계부품에서 조립작업을 행하는 제3단계와,
    설계부품추상화부가 조립된 소프트웨어설계부품중에서 관련성이 있는 것들을 묶어서 추상화시키는 추상화작업을 행하는 제4단계와,
    설계부품분해부가 조립된 소프트웨어 설계부품 중에서 불필요하게 된 부품의 분해제거를 위한 분해작업을 행하는 제5단계와,
    설계부품전송관리부가 네트워크상에서의 다수의 설계자에 의한 협력설계처리를 위한 전송관리 제어작업을 행하는 제6단계와,
    멀티미디어설계처리부가 멀티미디어적인 소프트웨어설계처리작업을 행하는 제7단계와,
    가능현실셜계처리부가 가상현실환경에서의 소프트웨어설계처리를 위한 가상현실제어작업을 행하는 제8단계와,
    설계단계와 프로그램코드 구현단계와의 상호변환(forward and reverse engineering)을 지원하는 변환작업을 행하는 제9단계를 포함하는 조립식 소프트웨어 설계처리장치의 작동방법.
  10. 제 9 항에 있어서,
    상기 조립식 소프트웨어 설계처리장치의 설계부품 조립부가 조립작업을 행하는 제3단계 후에, 필요한 경우에, 보수부품을 사용하여 소프트웨어설계도를 보수하는 단계를 추가적으로 포함하는 것을 특징으로 하는 조립식 소프트웨어 설계처리장치의 작동방법.
  11. 제 9 항에 있어서,
    상기 조립식 소프트웨어 설계처리장치의 설계부품조립부가 조립작업을 행하는 제3단계와,
    설계도에 여유공간을 자동으로 확보하는 단계와, 기본부품 및/또는 블록부품을 선택하여 삽입하는 단계를 포함하는 것을 특징으로 하는 조립식 소프트웨어 설계처리장치의 작동방법.
  12. 제 9 항에 있어서,
    상기 조립식 소프트웨어 설계처리장치의 설계부품추상화부가 조립된 소프트웨어 설계부품중에서 관련성이 있는 것들을 묶어서 추상화시키는 추상화작업을 행하는 제4단계는, 추상화시키려고 하는 범위를 자동으로 인식하는 단계와, 지정된 범위를 원하는 구조부품으로 추상화시키는 단계와, 설계부품들의 배열의 모양을 자동적으로 정돈시키는 단계를 포함하는 것을 특징으로 하는 조립식 소프트웨어 설계처리장치의 작동방법.
  13. 제 9 항에 있어서,
    상기 조립식 소프트웨어 설계처리장치의 설계부품분해부가 조립된 소프트웨어 설계부품들중에서 불필요하게 된 부품의 분해제거를 위한 분해작업을 행하는 제5단계는, 분해제거하려고 하는 블록 또는 구조의 범위를 자동으로 인식하는 단계와, 인식된 범위의 블록 또는 구조부품을 자동적으로 분해제거하는 단계와, 분해제거후의 여백을 남은 부품들이 자동적으로 메꾸어 정돈하는 단계를 포함하는 것을 특징으로 하는 조립시 소프트웨어 설계처리장치의 작동방법.
  14. 제 9 항에 있어서,
    상기 조립식 소프트웨어 설계처리장치의 조립식 소프트웨어 설계처리를 총괄제어하는 중앙설계 제어부가 총괄적인 설계제어작업을 행하기시작하는 제1단계는, 설계도상에서 상위모듈과 하위모듈간에 자동적인 위치인식에 의한 이동이 가능하게 되도록 하는 단계를 포함하는 것을 특징을 하는 조립식 소프트웨어 설계처리장치의 작동방법.
  15. 제 9 항에 있어서,
    상기 조립식 소프트웨어 설계처리장치의 조립식 소프트웨어 설계처리를 총괄제어하는 중앙설계 제어부가 총괄적인 설계제어작업을 행하기시작하는 제1단계는,조립식 소프트웨어 설계부품을 조립 및 분해하는 과정에서 이것에 필요한 부품을 규격화 및 표준화하여 항상 필요한 부품을 유지하는 단계를 포함하는 것을 특징으로 하는 조립식 소프트웨어 설계처리장치의 작동방법.
  16. 제 9 항에 있어서,
    상기 조립식 소프트웨어 설계처리장치의 조립식 소프트웨어설계처리를 총괄제어하는 중앙설계제어부가 총괄적인 설계제어작업을 행하기 시작하는 제1단계는, 조립식 소프트웨어 설계부품을 조립 또는 분해하는 과정에서 작성된 모듈로 가지않고 그 모듈을 호출해주는 상위모듈에서 직접 하위모듈의 이름등의 최소한의 정보만으로도 하위모듈에 관련된 모든 정보를 자동검색하여 지정한 모듈에 대한 설명이, 멀티미디어로 행해지도록 하는 것을 특징으로 하는 조립식 소프트웨어 설계처리장치의 작동방법.
  17. 제 9 항에 있어서,
    상기 조립식 소프트웨어 설계처리장치에서 처리하는 과정에서 모듈의 작성 및 테스트, 출력 등을 음성, 영상 등의 멀티미디어 매체를 통하여 행하는 것 및/또는 가상현실기법을 이동하여 3차원적인 도면영상의 관찰과 체감하면서 행하는 것을 특징으로 하는 조립식 소프트웨어 설계처리장치의 작동방법.
  18. 제 9 항에 있어서,
    상기 조립식 소프트웨어 설계처리장치에서 처리하는 과정에서 설계도에 기입되는 명세, 기능, 제어, 자료 등을 시작으로 하는 설계요소 및/또는 작성명령 등이 멀티미디어방식으로 행해지도록 하는 것을 특징으로 하는 조립식 소프트웨어 설계처리장치의 작동방법.
  19. 제 9 항이 있어서,
    상기 조립식 소프트웨어 설계처리장치에서 처리하는 과정에서 설계도의 작성을 네트워크상에서 다수의 사람들이 협력하여 동시에 여러겹으로 설계도를 작성하는 것을 특징으로 하는 조립식 소프트웨어 설계처리장치의 작동방법.
  20. 제 9 항에 있어서,
    상기 조립식 소프트웨어 설계처리장치로 처리하는 과정에서 설계도상에서 추상화된 개요만을 자동으로 추출하여 재구성하는 단계를 포함하는 것을 특징으로 하는 조립식 소프트웨어 설계처리장치의 작동방법.
  21. 제 10 항에 있어서,
    상기 조립식 소프트웨어 설계처리장치의 처리과정에서 보수부품을 사용하여 소프트웨어설계도를 보수하는 단계는, 보수부품이 삽입되는 위치를 인식하는 단계와, 상기의 인식된 위치에 보수부품을 삽입하는 단계를 포함하는 것을 특징으로 하는 조립식 소프트웨어 설계처리장치의 작동방법.
  22. 제 15 항에 있어서,
    상기 조립식 소프트웨어 설계처리장치에서 처리하는 과정에서 새롭게 요구된 기본부품, 블록부품, 구조부품 등의 조립에 있어서 추가적으로 필요한 부품을 규격화 및 표준화시켜서 새로운 부품으로 추가 등록가능하게 하는 조립식 소프트웨어 설계처리장치의 작동방법.
  23. 제 15 항에 있어서,
    상기 조립식 소프트웨어 설계처리장치에서 처리하는 과정에서 더이상 효용성이 없게되었다고 판명된 부품을 등록해제하는 것을 특징으로 하는 조립식 소프트웨어 설계처리장치의 작동방법.
  24. 제 22 항에 있어서,
    상기 조립식 소프트웨어 설계처리장치에서 처리하는 과정에서 조립식 소프트웨어 설계부품중에서 원하는 모양 및/또는 크기의 소프트웨어 설계부품을 새롭게 추가로 제작등록하여 조립하는 것을 특징으로 하는 조립식 소프트웨어 설계처리장치의 작동방법.
  25. 제 22 항에 있어서,
    상기 조립식 소프트웨어 설계처러장치에서 처리하는 과정에서 조립식 소프트웨어설계에 필요한 설계부품을 새롭게 제작등록함에 있어서, 음성이라던가 영상 등과 같은 멀티미디어 형태의 부품을 제작등록하여 조립하는 것을 특징으로 하는 조립식 소프트웨어 설계처리장치의 작동방법.
  26. 제 17 항에 있어서,
    상기 조립식 소프트웨어 설계처리장치의 처리과정에서, 설계도의 소정부분을 음성, 영상등과 같은 멀티미디어형태로 출력하는 것을 특징으로 하는 조립식 소프트웨어 설계처리장치의 작동방법.
  27. 제 17 항에 있어서,
    상기 조립식 소프트웨어 설계처리장치에서 처리하는 과정에서, 리스트가 필요하게 될 경우에 모듈의 테스트가 멀티미디어방식으로 행해지도록 하는 것을 특징으로 하는 조립식 소프트웨어 설계처리장치의 작동방법.
  28. 제 17 항에 있어서,
    상기 조립식 소프트웨어 설계처리장치에서 처리하는 과정에서, 필요하게 될 경우에 가상현실기법을 적용하여 오감으로 느끼면서 모듈의 조립, 분해 및 테스트를 행할 수가 있는 것을 특징으로 하는 조립식 소프트웨어 설계처리장치의 작동방법.
  29. 제 24 항에 있어서,
    상기 새롭게 제작되는 조립식 소프트웨어 설계부품중에서 필요부분을 묶어서 추상화시키는 것을 특징으로 하는 조립식 소프트웨어 설계처리장치의 작동방법.
  30. 제 9 항에 있어서,
    상기 조립식 소프트웨어 설계처리장치에서 처리하는 과정에서 설계단계와 프로그램코드구현단계와의 상호변환{forward and reverse engineering)을 지원하는 변환작업을 행하는 제9단계는, 설계단계와 분석단계와의 상호변환(forward and reverse enginsering)을 지원하는 변환작업을 추가적으로 포함하는 것을 특징으로 하는 조립식 소프트웨어 설계처리장치의 작동방법.
KR1019940034014A 1994-12-13 1994-12-13 조립식소프트웨어설계부품과그조립및분해방법 KR100367134B1 (ko)

Priority Applications (3)

Application Number Priority Date Filing Date Title
KR1019940034014A KR100367134B1 (ko) 1994-12-13 1994-12-13 조립식소프트웨어설계부품과그조립및분해방법
PCT/KR1995/000161 WO1996018944A1 (fr) 1994-12-13 1995-12-13 Appareil de traitement de conception de logiciel du type a assemblage
AU41903/96A AU4190396A (en) 1994-12-13 1995-12-13 Assembly type software design processing apparatus

Applications Claiming Priority (1)

Application Number Priority Date Filing Date Title
KR1019940034014A KR100367134B1 (ko) 1994-12-13 1994-12-13 조립식소프트웨어설계부품과그조립및분해방법

Publications (2)

Publication Number Publication Date
KR960024909A KR960024909A (ko) 1996-07-20
KR100367134B1 true KR100367134B1 (ko) 2003-03-12

Family

ID=19401328

Family Applications (1)

Application Number Title Priority Date Filing Date
KR1019940034014A KR100367134B1 (ko) 1994-12-13 1994-12-13 조립식소프트웨어설계부품과그조립및분해방법

Country Status (3)

Country Link
KR (1) KR100367134B1 (ko)
AU (1) AU4190396A (ko)
WO (1) WO1996018944A1 (ko)

Cited By (2)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
KR20160084026A (ko) 2015-01-05 2016-07-13 유홍준 조립식 패턴진화 통합 모델링 기반 컴퓨터적사고 증진 방법 및 시스템
KR20200106783A (ko) 2019-03-05 2020-09-15 국방과학연구소 도메인 에셋 정보 제공 방법 및 장치

Citations (5)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
JPS58169244A (ja) * 1982-03-31 1983-10-05 Fujitsu Ltd プログラム開発方式
JPH02128234A (ja) * 1988-11-09 1990-05-16 Nec Corp 試験プログラム作成管理方式
JPH02207325A (ja) * 1989-02-08 1990-08-17 Hitachi Software Eng Co Ltd ソースプログラム自動生成方式
US5325533A (en) * 1993-06-28 1994-06-28 Taligent, Inc. Engineering system for modeling computer programs
JPH101994A (ja) * 1996-06-17 1998-01-06 Naoya Suzuki 腰掛便器での男子用排尿介助器

Family Cites Families (8)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
JPS6289137A (ja) * 1985-10-16 1987-04-23 Hitachi Ltd プログラム対話方式
JPS6373475A (ja) * 1986-09-17 1988-04-04 Fujitsu Ltd 二次元プログラム言語構造解析処理方式
JPS63197229A (ja) * 1987-02-12 1988-08-16 Fujitsu Ltd モジユ−ル構造自動生成方式
JPH01142828A (ja) * 1987-11-30 1989-06-05 Nec Corp ソフトウェア開発ステーション
JPH01173131A (ja) * 1987-12-28 1989-07-07 Toshiba Corp 構造エディタ
JPH0724022B2 (ja) * 1989-06-30 1995-03-15 横河電機株式会社 プログラム言語変換方法
JPH04235630A (ja) * 1990-07-30 1992-08-24 Ronald L Colier 可聴コマンドでコンピュータのプログラミングを行うための方法及び装置
JPH04344932A (ja) * 1991-05-22 1992-12-01 Hitachi Ltd 分散プログラミング方法

Patent Citations (5)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
JPS58169244A (ja) * 1982-03-31 1983-10-05 Fujitsu Ltd プログラム開発方式
JPH02128234A (ja) * 1988-11-09 1990-05-16 Nec Corp 試験プログラム作成管理方式
JPH02207325A (ja) * 1989-02-08 1990-08-17 Hitachi Software Eng Co Ltd ソースプログラム自動生成方式
US5325533A (en) * 1993-06-28 1994-06-28 Taligent, Inc. Engineering system for modeling computer programs
JPH101994A (ja) * 1996-06-17 1998-01-06 Naoya Suzuki 腰掛便器での男子用排尿介助器

Cited By (2)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
KR20160084026A (ko) 2015-01-05 2016-07-13 유홍준 조립식 패턴진화 통합 모델링 기반 컴퓨터적사고 증진 방법 및 시스템
KR20200106783A (ko) 2019-03-05 2020-09-15 국방과학연구소 도메인 에셋 정보 제공 방법 및 장치

Also Published As

Publication number Publication date
WO1996018944A1 (fr) 1996-06-20
KR960024909A (ko) 1996-07-20
AU4190396A (en) 1996-07-03

Similar Documents

Publication Publication Date Title
US9754059B2 (en) Graphical design verification environment generator
Zimmermann et al. Petri net modelling and performability evaluation with TimeNET 3.0
CA1285655C (en) Graphical system for modelling a process and associated method
US7240317B2 (en) Placement/net wiring processing system
EP0433066A2 (en) Common symbol library architecture
US6230305B1 (en) Methods and apparatus for configuring schematic diagrams
US5367468A (en) Design aid method and design aid apparatus for integrated circuits
JPS6365965B2 (ko)
JPH08123836A (ja) 会話型回路設計装置
JPH01309185A (ja) Asic用計算機支援設計システム
JPH05233590A (ja) ペトリネットによる生産システムシミュレータ装置
KR100367134B1 (ko) 조립식소프트웨어설계부품과그조립및분해방법
JP3926496B2 (ja) プロジェクト管理システム
Graf A visual environment for the design of distributed systems
De Ruvo et al. An eclipse-based editor to support lotos newcomers
Babb Data-driven implementation of data flow diagrams
Nguyen Thanh et al. VeBPRu: A Toolchain for Formally Verifying Business Processes and Business Rules
Hartson et al. Developing human‐computer interface models and representation techniques
JP2012088933A (ja) ソフトウェアプロダクトライン開発支援装置、その方法およびそのプログラム
CN107122226B (zh) 一种模拟软件场景的方法与系统
JPH04290168A (ja) シミュレーション装置とそのシミュレーション結果表示方法
Henschen et al. On the Integration of Multiple Modeling Methodologies into a Single User Interface
Barros et al. Requirements specification for controller design—From use cases to IOPT net models
JP2937381B2 (ja) 集積回路の設計方法及び設計装置
JPH01309146A (ja) プロセス監視装置及びそれに使用されるネットワーク図の作成方法

Legal Events

Date Code Title Description
A201 Request for examination
E902 Notification of reason for refusal
E701 Decision to grant or registration of patent right
GRNT Written decision to grant
LAPS Lapse due to unpaid annual fee