6 research outputs found

    Effect of the Yield Criterion of Matrix on the Brittle Fracture of Fibres in Uniaxial Tension of Composites

    Get PDF
    This paper examines the effect of the yield criterion of the matrix on brittle fracture of the fibre in continuous fibre reinforced metal matrix composites subjected to tension in the direction parallel to the fibres. It is assumed that the matrix obeys quite a general isotropic yield criterion. An approximate approach to predicting the tensile load at which the fibre breaks previously proposed in the literature is adopted. It is shown that this tensile load is practically independent of the yield criterion of the matrix. This is a great advantage for engineering applications since an analytic solution is available in the case of Tresca yield criterion. This solution can be used for a wide range of matrix materials with no loss of the accuracy of the prediction of the tensile load at which the fibre breaks

    SmartCheck: Static Analysis of Ethereum Smart Contracts

    Get PDF
    Ethereum is a major blockchain-based platform for smart contracts – Turing complete programs that are executed in a decentralized network and usually manipulate digital units of value. Solidity is the most mature high-level smart contract language. Ethereum is a hostile execution environment, where anonymous attackers exploit bugs for immediate financial gain. Developers have a very limited ability to patch deployed contracts. Hackers steal up to tens of millions of dollars from flawed contracts, a well-known example being “The DAO“, broken in June 2016. Advice on secure Ethereum programming practices is spread out across blogs, papers, and tutorials. Many sources are outdated due to a rapid pace of development in this field. Automated vulnerability detection tools, which help detect potentially problematic language constructs, are still underdeveloped in this area. We provide a comprehensive classification of code issues in Solidity and implement SmartCheck – an extensible static analysis tool that detects them. SmartCheck translates Solidity source code into an XML-based intermediate representation and checks it against XPath patterns. We evaluated our tool on a big dataset of real-world contracts and compared the results with manual audit on three contracts. Our tool reflects the current state of knowledge on Solidity vulnerabilities and shows significant improvements over alternatives. SmartCheck has its limitations, as detection of some bugs requires more sophisticated techniques such as taint analysis or even manual audit. We believe though that a static analyzer should be an essential part of contract developers’ toolbox, letting them fix simple bugs fast and allocate more effort to complex issues
    corecore