GraphMT Software Engineer Job at Interclypse Inc

Interclypse Inc Annapolis Junction, MD 20701

Description:

Interclypse is seeking a Software Engineer

The Interclypse difference is our emphasis on employee growth and development through continuous learning, mentorship, and empowerment. Interclypse employees grow in a positive cultivating work environment with endless career opportunities. Let Interclypse empower you by putting you in the driver's seat of your career.

The Software Engineer designs, develops, tests, deploys, documents, maintains, and enhances complex and diverse software systems based upon documented requirements. These systems might include, but are not limited to, processing ¬intensive analytics, novel algorithm development, manipulation of extremely large data sets, real-time systems, business management information systems, and systems that incorporate data repositories, data transport services, and application and systems development and monitoring. Works individually or as part of a team. Reviews and tests software components for adherence to the design requirements and documents test results. Resolves software problem reports. Utilizes software development and software design methodologies appropriate to the development environment. Provides specific input to the software components of system design to include hardware/software trade-offs, software reuse, use of Open Source Software (OSS) and/or Commercial Off ¬The-Shelf (COTS) Government Off-The-Shelf (GOTS)software in place of new development, and requirements analysis and synthesis from system level to individual software components. Experience developing in Unix. Ability to perform shell scripting. Working knowledge of Configuration Management (CM) tools and Web Services implementation.

GraphMT is the next-generation computing platform for decentralized, persistent memory graph analysis. The core architecture of GraphMT is object-oriented and templated C++ classes for managing threads, parallel I/O, and shared memory segments in a Unix computing environment.

The ideal candidate will design and implement new core functions to improve resource allocation and performance for concurrent updates to an in-memory graph, support discovery and monitoring of GraphMT instances, implement new graph data structures and parallel algorithms, and integrate support for parallel I/O from multiple sources, protocols, and various file formats.

Requirements:
  • Bachelor's degree in Computer Science or related discipline and five (5) years of relevant experience
  • Analyze user requirements to derive software design and performance requirements.
  • Debug existing software and correct defects.
  • Design and code new software or modify existing software to add new features.
  • Write or review software and system documentation.
  • Integrate existing software into new or modified systems or operating environments.
  • Develop simple data queries for existing or proposed databases or data repositories.
  • Software development using languages such as C, C++, Python, Ruby, Perl, JavaScript, etc.
  • Has experience with agile development processes.
  • Has experience with source code control systems, such as Git.
  • Serve as team lead at the level appropriate to the software development process being used on any project.
  • Design and development of relational and non-relational database applications.
  • Use of orchestration frameworks such as Spring and Kafka.
  • Familiarization with queue management systems
  • Develop or implement algorithms to meet or exceed system performance and functional standards.
  • Develop and execute test procedures for software components.
  • Develop software solutions by analyzing system performance standards and conferring with users or system engineers; analyzing systems flow, data usage, and work processes; and investigating problem areas.
  • Modify existing software to adapt to new hardware or to improve its performance
  • Design, develop, and modify software systems using scientific analysis and mathematical models to predict and measure outcomes and consequences of design decisions
  • Java development using the Eclipse IDE (Integrated Development Environment).
  • Development of Java 2 Enterprise Edition (J2EE) applications
  • Experience using collaboration and software development tools (ie. Atlassian).
  • Software development using continuous integration practices
  • Experience with container technologies (ie. Docker).
  • Unix shell scripting
  • Development of event-driven, or data-driven analytics
  • Development of cloud-based solutions and technologies.
  • Design or implement complex algorithms requiring adherence to strict timing, system resource, or interface constraints. Perform quality control on team products.
  • Recommend and implement suggestions for improving documentation and software development process standards.
  • Oversee one or more software development teams and ensure the work is completed in accordance with the constraints of the software development process being used on any project.
  • Confer with system engineers and hardware engineers to derive software requirements and to obtain information on project limitations and capabilities, performance requirements, and interfaces.
  • Coordinate software installation on a system and monitor performance to ensure operational specifications are met.

Task Required Skills

  • Experience using the Unix CLI
  • Experience developing scripts using Bash, Python
  • Within the last 3 years, experience developing with C++ in a Unix computing environment that utilizes multi-platform shared-memory, multiprocessing, and multithreading programming skills
  • Experience using the Unix GCC compiler
  • Experience using Unix software libraries and packages
  • Experience with POSIX threads, OpenMP, and Sys V (or POSIX) shared memory

Task Desired Skills

  • General knowledge of Graph Theory principles and concepts
  • Experience with the Atlassian Suite of Tools (Jira, Confluence)
  • Experience with Git Version Control

EOE AA M/F/Vet/Disability:

Interclypse is an Equal Opportunity/Affirmative Action employer. All qualified applicants will receive consideration for employment without regard to race, color, religion, creed, sex, sexual orientation, gender identity, national origin, disability, or protected Veteran status.




Please Note :
ajayjain.com is the go-to platform for job seekers looking for the best job postings from around the web. With a focus on quality, the platform guarantees that all job postings are from reliable sources and are up-to-date. It also offers a variety of tools to help users find the perfect job for them, such as searching by location and filtering by industry. Furthermore, ajayjain.com provides helpful resources like resume tips and career advice to give job seekers an edge in their search. With its commitment to quality and user-friendliness, Site.com is the ideal place to find your next job.